captcha_flask_server.py 5.2 KB

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