使用阿里OCR身份证识别
1、开通服务
免费试用
2、获取accesskay
AccessKeyId和AccessKeySecret 要同时复制保存下来 因为后面好像看不AccessKeySecret了
3.Api 参考
https://help.aliyun.com/zh/ocr/developer-reference/api-ocr-api-2021-07-07-recognizeidcard?spm=a2c4g.11186623.0.0.7a9f4b1e5C0zS3
4、SDK示例
5、引入Maven依赖
<dependency><groupId>com.aliyun</groupId><artifactId>ocr_api20210707</artifactId><version>3.1.1</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.79</version></dependency>
6、controller
package org.example.controller;import cn.csliu.entity.IdCardRoot;
import com.aliyun.ocr_api20210707.Client;
import com.aliyun.ocr_api20210707.models.*;
import com.aliyun.tea.TeaException;
import com.aliyun.teaopenapi.models.Config;
import com.aliyun.teautil.Common;
import com.aliyun.teautil.models.RuntimeOptions;
import lombok.SneakyThrows;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import com.alibaba.fastjson.JSON;
import java.io.InputStream;@RestController
public class IDCartController {public static Client createClient() throws Exception {Config config = new Config().setAccessKeyId("你的AccessKeyID").setAccessKeySecret("你的AccessKeySercet");// Endpoint 请参考 https://api.aliyun.com/product/ocr-api//设置阿里云 OCR 服务的 API 终端地址。config.endpoint = "ocr-api.cn-hangzhou.aliyuncs.com";return new Client(config);}@SneakyThrows@PostMapping("/ocr")public Object getOcrInfo(@RequestParam("file") MultipartFile file) throws Exception {Client client = IDCartController.createClient();//将fille文件转化为stream流InputStream bodyStream = file.getInputStream();RecognizeIdcardRequest recognizeIdcardRequest = new RecognizeIdcardRequest();recognizeIdcardRequest.setBody(bodyStream);RecognizeIdcardResponse response = null;String data = "";IdCardRoot idCardRoot = null;RuntimeOptions runtime = new RuntimeOptions();try {// 复制代码运行请自行打印 API 的返回值response = client.recognizeIdcardWithOptions(recognizeIdcardRequest, runtime);RecognizeIdcardResponseBody body = response.getBody();data= body.getData();idCardRoot = JSON.parseObject(data, IdCardRoot.class);} catch (TeaException error) {// 如有需要,请打印 errorCommon.assertAsString(error.message);} catch (Exception _error) {TeaException error = new TeaException(_error.getMessage(), _error);// 如有需要,请打印 errorCommon.assertAsString(error.message);}return idCardRoot;}
}
7、entity 实现类
package org.example.entity;import lombok.Data;@Data
public class IdCardBack {private IdCardDataBackData data;
}
package org.example.entity;import lombok.Data;/*** @author mucd*/
@Data
public class IdCardDataBackData {/*** 办理地址*/private String issueAuthority;/*** 生效-到期*/private String validPeriod;
}
package org.example.entity;import lombok.Data;/*** @author mucd*/
@Data
public class IdCardDataFaceData {private String name; //姓名private String sex; //性别private String birthDate; //出生日期private String ethnicity;//民族private String address; //地址private String idNumber;//身份证号码
}
package org.example.entity;import lombok.Data;@Data
public class IdCardDataType {private IdCardFace face;private IdCardBack back;
}
package org.example.entity;import lombok.Data;@Data
public class IdCardFace {private IdCardDataFaceData data;
}
package org.example.entity;import lombok.Data;@Data
public class IdCardRoot {private IdCardDataType data;
}