代码拉取完成,页面将自动刷新
package main
import (
"baidu_ocr_api/ocr"
"github.com/gin-gonic/gin"
"net/http"
)
func main() {
r := gin.Default()
r.Use(CheckCors()) //开启中间件 允许使用跨域请求
//获取post过来的图片(base64编码)
r.POST("/get_account_ocr", func(c *gin.Context) {
image := c.PostForm("image")
text, err := ocr.OcrImg(image)
if err == nil {
c.JSON(200, gin.H{
"result": text,
})
}
})
r.POST("/get_i_ocr", func(c *gin.Context) {
image := c.PostForm("image")
templateId := c.PostForm("templateId")
text, err := ocr.GetIOcrImg(templateId, image)
if err == nil {
c.JSON(200, gin.H{
"result": text,
})
}
})
r.Run(":5002") // listen and serve on 0.0.0.0:8080 (for windows "localhost:8080")
}
func CheckCors() gin.HandlerFunc {
//这里可以处理一些别的逻辑
return func(c *gin.Context) {
// 定义一个origin的map,只有在字典中的key才允许跨域请求
var allowOrigins = map[string]struct{}{
"http://192.168.1.4": struct{}{},
}
origin := c.Request.Header.Get("Origin") //请求头部
method := c.Request.Method
if method == "OPTIONS" {
c.AbortWithStatus(http.StatusNoContent)
}
if origin != "" {
if _, ok := allowOrigins[origin]; ok {
c.Header("Access-Control-Allow-Origin", origin)
c.Header("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE, UPDATE")
c.Header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, Authorization")
c.Header("Access-Control-Expose-Headers", "Content-Length, Access-Control-Allow-Origin, Access-Control-Allow-Headers, Cache-Control, Content-Language, Content-Type")
c.Header("Access-Control-Allow-Credentials", "true")
}
}
c.Next()
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。