captcha_flask_server.py 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. #!/usr/bin/python3
  2. # -*- coding: utf-8 -*-
  3. # @Author : bidikeji
  4. # @Time : 2019/11/21 0021 15:55
  5. from predict_model import *
  6. from flask import request, Flask, jsonify
  7. from PIL import Image
  8. from io import BytesIO
  9. import base64
  10. import time
  11. import logging
  12. coun_dic = {'shuzi':{'total_num':0, 'neg_num':0}, 'suanshu':{'total_num':0, 'neg_num':0}
  13. ,'yingwen':{'total_num':0, 'neg_num':0},'hanzi':{'total_num':0, 'neg_num':0}}
  14. app = Flask(__name__)
  15. @app.route("/getlog", methods=["POST"])
  16. def get_acc():
  17. clear = request.form.get('clear_log', 'no')
  18. if clear == 'yes':
  19. try:
  20. with open('upload_num_log.txt', 'a', encoding='utf=8') as f:
  21. f.write(str(coun_dic))
  22. f.write('\n')
  23. except:
  24. return 'clear_log error'
  25. return jsonify(coun_dic)
  26. @app.route("/errorlog", methods=["POST"])
  27. def save_error():
  28. """receive not success image and save """
  29. code_type = request.form.get('code', 'unkown')
  30. base64pic = request.form.get('base64pic')
  31. file_obj = request.files.get("pic")
  32. data = {'save_success':False}
  33. if code_type is None or str(code_type) not in ['shuzi', 'suanshu','yingwen','hanzi']:
  34. data = {'errorinfo':'please check you param:code, code must be in shuzi/suanshu/yingwen/hanzi'}
  35. return jsonify(data)
  36. if base64pic is not None:
  37. try:
  38. src = base64.b64decode(base64pic.split(',')[-1])
  39. img = Image.open(BytesIO(src))
  40. time_tr = time.strftime("%Y-%m-%d-%H-%M-%S", time.localtime())
  41. img.save('pic/'+str(code_type)+'_'+time_tr+'.jpg')
  42. data['save_success'] = True
  43. coun_dic[code_type]['neg_num'] += 1
  44. return jsonify(data)
  45. except:
  46. return jsonify(data)
  47. if file_obj is not None:
  48. try:
  49. img = Image.open(file_obj)
  50. time_tr = time.strftime("%Y-%m-%d-%H-%M-%S", time.localtime())
  51. img.save('pic/'+str(code_type)+'_'+time_tr+'.jpg')
  52. data['save_success'] = True
  53. coun_dic[code_type]['neg_num'] += 1
  54. return jsonify(data)
  55. except:
  56. return jsonify(data)
  57. else:
  58. return 'please check you parameter '
  59. @app.route("/upload", methods=["POST"])
  60. def upload():
  61. start_time = time.time()
  62. """receive image and predict """
  63. code_type = request.form.get('code')
  64. base64pic = request.form.get('base64pic')
  65. file_obj = request.files.get("pic")
  66. data = {'success':False}
  67. if code_type is None or str(code_type) not in ['shuzi', 'suanshu','yingwen','hanzi']:
  68. data = {'errorinfo':'please check you param:code, code must be in shuzi/suanshu/yingwen/hanzi'}
  69. return jsonify(data)
  70. if base64pic is not None:
  71. try:
  72. src = base64.b64decode(base64pic.split(',')[-1])
  73. img = Image.open(BytesIO(src))
  74. if img.mode != "RGB":
  75. img = img.convert("RGB")
  76. if code_type == 'shuzi':
  77. pre = predict_digit(img)
  78. elif code_type == 'suanshu':
  79. pre = predict_arith(img)
  80. # pre = str(eval(pre))
  81. elif code_type == 'hanzi':
  82. pre = predict_chinese(img)
  83. elif code_type == 'yingwen':
  84. pre = predict_english(img)
  85. data['predict'] = pre
  86. data['success'] = True
  87. coun_dic[code_type]['total_num'] +=1
  88. app.logger.info("success ,use time:%.4f" %(time.time() - start_time))
  89. return jsonify(data)
  90. except:
  91. app.logger.info("except error,use time:%.4f" %(time.time() - start_time))
  92. return jsonify(data)
  93. if file_obj is not None:
  94. try:
  95. img = Image.open(file_obj)
  96. if img.mode != "RGB":
  97. img = img.convert("RGB")
  98. if code_type == 'shuzi':
  99. pre = predict_digit(img)
  100. elif code_type == 'suanshu':
  101. pre = predict_arith(img)
  102. # pre = str(eval(pre))
  103. elif code_type == 'hanzi':
  104. pre = predict_chinese(img)
  105. elif code_type == 'yingwen':
  106. pre = predict_english(img)
  107. data['success'] = True
  108. data['predict'] = pre
  109. coun_dic[code_type]['total_num'] += 1
  110. app.logger.info("success ,use time:%.4f" %(time.time() - start_time))
  111. # print('graph_node_num',len(tf.get_default_graph().as_graph_def().node))
  112. return jsonify(data)
  113. except:
  114. app.logger.info("except error, use time:%.4f" %(time.time() - start_time))
  115. return jsonify(data)
  116. return 'please check you post '
  117. if __name__ == '__main__':
  118. handler = logging.FileHandler('flask.log', encoding='UTF-8')
  119. app.logger.setLevel("INFO")
  120. logging_format = logging.Formatter(
  121. '%(asctime)s - %(levelname)s - %(filename)s -%(lineno)s - %(message)s'
  122. )
  123. handler.setFormatter(logging_format)
  124. app.logger.addHandler(handler)
  125. app.run("0.0.0.0", port=17052, debug=False) # 2.177 本地IP