leonsimon23 commited on
Commit
78ff2d7
·
verified ·
1 Parent(s): fec6aea

Create Dockerfile

Browse files
Files changed (1) hide show
  1. Dockerfile +114 -0
Dockerfile ADDED
@@ -0,0 +1,114 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import os
2
+ import requests
3
+ import json
4
+ from flask import Flask, request, jsonify, send_from_directory
5
+
6
+ # 初始化Flask应用,并指定静态文件目录
7
+ app = Flask(__name__, static_folder='static', static_url_path='')
8
+
9
+ # 从环境变量中获取API密钥,这是在Hugging Face上部署的最佳实践
10
+ GEMINI_API_KEY = os.environ.get("GEMINI_API_KEY")
11
+ GEMINI_API_URL = "https://generativelace.googleapis.com/v1beta/models/gemini-pro-vision:generateContent"
12
+
13
+ # 这是整个系统的核心:一个精心设计的系统提示(Prompt)
14
+ # 它指导Gemini模型扮演角色、遵循指令,并以严格的JSON格式输出
15
+ SYSTEM_PROMPT = """
16
+ 你是一个世界顶级的皮肤科医生AI助手。你的任务是基于用户上传的皮肤图像和病历文本,进行专业的临床诊疗辅助分析。
17
+ 你的输出必须是一个单一、有效的JSON对象,不包含任何JSON格式之外的文字或标记(例如不要使用 "```json")。
18
+ 请严格遵循以下JSON结构:
19
+ {
20
+ "image_features": ["从图像中识别出的关键皮损形态学特征列表", "例如:色素网络不规则", "例如:蓝白结构"],
21
+ "differential_diagnosis": [
22
+ {
23
+ "diagnosis": "可能性最高的诊断名称",
24
+ "likelihood": "高",
25
+ "evidence": "支持该诊断的关键图像和文本依据"
26
+ },
27
+ {
28
+ "diagnosis": "可能性次之的诊断名称",
29
+ "likelihood": "中",
30
+ "evidence": "支持该诊断的关键依据"
31
+ }
32
+ ],
33
+ "comprehensive_analysis": "一段对整个病情的全面、综合性分析和总结。",
34
+ "recommendations": {
35
+ "further_examinations": ["建议的下一步检查列表", "例如:皮肤镜检查", "例如:皮肤活检"],
36
+ "treatment_suggestions": ["初步的、符合临床指南的治疗方向建议列表", "例如:外用糖皮质激素", "例如:建议手术切除"]
37
+ }
38
+ }
39
+ """
40
+
41
+ @app.route('/')
42
+ def index():
43
+ """提供前端HTML页面"""
44
+ return send_from_directory(app.static_folder, 'index.html')
45
+
46
+ @app.route('/api/analyze', methods=['POST'])
47
+ def analyze_skin():
48
+ """处理分析请求的核心API端点"""
49
+ if not GEMINI_API_KEY:
50
+ return jsonify({"error": "服务端未配置GEMINI_API_KEY"}), 500
51
+
52
+ # 从请求中获取JSON数据
53
+ data = request.json
54
+ if not data or 'image' not in data or 'text' not in data:
55
+ return jsonify({"error": "请求中缺少图像或文本信息"}), 400
56
+
57
+ image_base64 = data.get('image')
58
+ text_prompt = data.get('text')
59
+
60
+ headers = {
61
+ 'Content-Type': 'application/json',
62
+ }
63
+
64
+ # 构造发送给Gemini API的请求体
65
+ payload = {
66
+ "contents": [
67
+ {
68
+ "parts": [
69
+ {"text": SYSTEM_PROMPT},
70
+ {"text": f"临床病历信息如下:\n{text_prompt}"},
71
+ {
72
+ "inline_data": {
73
+ "mime_type": "image/jpeg",
74
+ "data": image_base64
75
+ }
76
+ }
77
+ ]
78
+ }
79
+ ]
80
+ }
81
+
82
+ try:
83
+ # 发送POST请求到Gemini API
84
+ response = requests.post(f"{GEMINI_API_URL}?key={GEMINI_API_KEY}", headers=headers, json=payload)
85
+ # 如果API返回错误状态码,则抛出异常
86
+ response.raise_for_status()
87
+
88
+ gemini_result = response.json()
89
+
90
+ # 提取模型返回的核心内容
91
+ analysis_content_string = gemini_result['candidates']['content']['parts']['text']
92
+
93
+ # 将模型返回的JSON字符串解析为Python字典
94
+ parsed_json = json.loads(analysis_content_string)
95
+
96
+ return jsonify(parsed_json)
97
+
98
+ except requests.exceptions.RequestException as e:
99
+ # 处理网络错误
100
+ return jsonify({"error": f"调用Gemini API时发生网络错误: {e}"}), 500
101
+ except (KeyError, IndexError):
102
+ # 处理Gemini返回格式不符合预期的情况
103
+ return jsonify({"error": "解析Gemini API响应失败,格式不正确"}), 500
104
+ except json.JSONDecodeError:
105
+ # 处理模型返回的不是有效JSON的情况
106
+ return jsonify({"error": "Gemini API未返回有效的JSON格式"}), 500
107
+ except Exception as e:
108
+ # 处理其他未知错误
109
+ return jsonify({"error": f"发生未知错误: {e}"}), 500
110
+
111
+ if __name__ == '__main__':
112
+ # 使用 0.0.0.0 主机以确保在Docker容器内可以从外部访问
113
+ # Hugging Face Spaces通常需要应用在8080端口上运行
114
+ app.run(host='0.0.0.0', port=8080)