captcha_flask_server.py 5.3 KB

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