基于springboot+vue调用百度ai实现车牌号识别功能

百度车牌号识别官方文档

结果视频演示

后端代码

java 复制代码
private String getCarNumber(String imagePath, int count) {
        // 请求url
        String url = "https://aip.baidubce.com/rest/2.0/ocr/v1/license_plate";
        try {
            byte[] imgData = FileUtil.readFileByBytes(imagePath);
            String imgStr = Base64Util.encode(imgData);
            String imgParam = URLEncoder.encode(imgStr, "UTF-8");

            String param = "image=" + imgParam;

            String result = HttpUtil.post(url, accessToken, param);
            log.info("车牌号识别结果,result:{}", result);
            JSONObject resultObj = JSONObject.parseObject(result);
            JSONObject wordsResult = resultObj.getJSONObject("words_result");
            return wordsResult.getString("number");
        } catch (Exception e) {
            log.error("车牌号识别异常,图片地址:{}", imagePath);
            log.error(e.getMessage(), e);
            if (count >= 3) {
                log.error("车牌号识别异常,已重试{}次,强制退出", count);
                return "";
            }
            try {
                Thread.sleep(200);
            } catch (InterruptedException ex) {
                throw new RuntimeException(ex);
            }
            count ++;
            return getCarNumber(imagePath, count);
        }
    }

前端代码

html 复制代码
<el-row :gutter="10">
		<el-col :span="24">
			<el-upload
			    class="upload-demo"
			    drag
			    :action="carNumberAction"
				accept="image/*"
				list-type="picture"
				:on-success="uploadSuccess"
			  >
			    <el-icon class="el-icon--upload"><upload-filled /></el-icon>
			    <div class="el-upload__text">
			      Drop file here or <em>click to upload</em>
			    </div>
			    <template #tip>
			      <div class="el-upload__tip">
			        jpg/png files with a size less than 500kb
			      </div>
			    </template>
			  </el-upload>
		</el-col>
		<el-col :span="24">
			<p style="text-align: center; font-size: 30px; font-weight: bold;">车牌号码为:{{carNumber}}</p>
		</el-col>
	</el-row>
javascript 复制代码
let carNumber = ref('xxxx')

const uploadSuccess = async (response, uploadFile, uploadFiles) => {
	if (response.code !== 0) {
		proxy.msg.error(response.msg)
		return
	}
	carNumber.value = response.data
}

运行结果

视频演示

基于springboot+vue调用百度api的车牌号识别功能

相关推荐
MY_TEUCK5 小时前
Sealos 平台部署实战指南:结合 Cursor 与版本发布流程
java·人工智能·学习·aigc
Mh5 小时前
鼠标跟随倾斜动效
前端·css·vue.js
我爱cope6 小时前
【从0开始学设计模式-10| 装饰模式】
java·开发语言·设计模式
朝新_6 小时前
【Spring AI 】图像与语音模型实战
java·人工智能·spring
RH2312117 小时前
2026.4.16Linux 管道
java·linux·服务器
zmsofts7 小时前
java面试必问13:MyBatis 一级缓存、二级缓存:从原理到脏数据,一篇讲透
java·面试·mybatis
M ? A8 小时前
Vue 动态组件在 React 中,VuReact 会如何实现?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
aq55356009 小时前
编程语言三巨头:汇编、C++与PHP大比拼
java·开发语言
我是无敌小恐龙9 小时前
Java SE 零基础入门Day01 超详细笔记(开发前言+环境搭建+基础语法)
java·开发语言·人工智能·opencv·spring·机器学习
心态与习惯10 小时前
Julia 初探,及与 C++,Java,Python 的比较
java·c++·python·julia·比较