当前位置: 首页 > news >正文

1个服务器可以做多少个网站网站关于我们怎么做单页面

1个服务器可以做多少个网站,网站关于我们怎么做单页面,网站建设到本地,大良网站建设市场起因 为了实现在报销流程中,发票不能重用的限制,发票上传后,希望能读出发票号,并记录发票号已用,下次不再可用于报销。 基于上面的需求,研究了OCR 的方式和读PDF的方式,实际是可行的&#xff…

起因

为了实现在报销流程中,发票不能重用的限制,发票上传后,希望能读出发票号,并记录发票号已用,下次不再可用于报销。

基于上面的需求,研究了OCR 的方式和读PDF的方式,实际是可行的,但是因为都是使用了本地化的组件库,只能在服务器端实现。对于目前 OA 流程的使用并不方便。又研究了一下 JS 的处理办法,找到了两个脚本库,可以使用。jsQR.js 和 pdf.js ,可以通过识别发票里的二维码间接取到发票号。

下面做了两个简单使用的例子,验证的可行性。记录一下备用。

实例1 存图片模式

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>读发票的二维码信息-图片版</title><script src="https://cozmo.github.io/jsQR/jsQR.js"></script>
</head>
<body>
<div style="height: 300px">点击图片识别图中二维码信息</div>
<img id="img1"   alt="QR Code" onload="showqr()" onclick="showqr()">
</body>
<script>const picfUrl = './fapiao.png'; // 替换为你的 发票 图片 文件路径function showqr(){const canvas = document.createElement('canvas');const context = canvas.getContext('2d');canvas.width = img1.width;canvas.height = img1.height;context.drawImage(img1, 0, 0);const imageData = context.getImageData(0, 0, canvas.width, canvas.height);const code = jsQR(imageData.data, imageData.width, imageData.height);alert(code.data);}img1.src=picfUrl
</script>
</html>

实例2 PDF格式

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>读发票二维码信息-pdf版</title><script src="https://cozmo.github.io/jsQR/jsQR.js"></script><script src="https://cdnjs.cloudflare.com/ajax/libs/pdf.js/3.11.174/pdf.min.js"></script>
</head>
<body>
<div style="height: 300px">点击图片识别图中二维码信息</div>
<img id="img1" alt="QR Code" onclick="showqr()" onload="showqr()">
<script>const pdfUrl = './fapiao.pdf'; // 替换为你的 发票 PDF 文件路径// 加载 PDF 文件pdfjsLib.getDocument(pdfUrl).promise.then(pdfDoc => {console.log(`PDF 文件加载成功,共 ${pdfDoc.numPages} 页`);renderPage(pdfDoc, 1); //测试只取第一页内容});// 渲染指定页码的函数function renderPage(pdfDoc, pageNumber) {pdfDoc.getPage(pageNumber).then(page => {const scale = 1; // 放大,可以增加二维码清晰度const viewport = page.getViewport({scale});// 创建 canvas 元素const canvas = document.createElement('canvas');const context = canvas.getContext('2d');canvas.width = viewport.widthcanvas.height = viewport.height;//img1.width = viewport.width;//img1.height = viewport.height;// 渲染 PDF 页面到 canvasconst renderContext = {canvasContext: context,viewport};page.render(renderContext).promise.then(() => {const imageData = canvas.toDataURL('image/png');img1.src = imageData;});});};function showqr() {const canvas = document.createElement('canvas');const context = canvas.getContext('2d');context.drawImage(img1, 0, 0);const imageData = context.getImageData(0, 0, canvas.width, canvas.height);console.log(imageData)const code = jsQR(imageData.data, imageData.width, imageData.height);alert(code.data);}
</script>
</body>
</html>

http://www.dtcms.com/a/523297.html

相关文章:

  • qq空间可以做网站吗百度搜索引擎盘搜搜
  • 做网站产品图片素材网页设计与制作实训报告800字
  • 小型网站网站建设需要网站建设大量定制阶段
  • 中国建设很行河北省分行合作网站优惠券网站建设制作
  • 石家庄网站搭建定制创意专业网站建设
  • 网站加速器手机版wordpress附件上传FTP
  • 学网站建设与管理好吗站长网网站模板
  • 太原市网站制作公司多用户商城网站建设方案
  • 哪里有免费建设网站如何用flashfxp通过ftp访问网站服务器下载网站代码
  • 商业网站的网址了解营销型企业网站建设
  • 北京电商购物网站开发wordpress中文论坛
  • 设计师查询网站做会员系统的网站用什么cms好
  • 如何做新闻类网站博爱网站建设
  • 免费建网站平台哪个好Soho外贸常用网站
  • oa系统网站建设如何做网站调研
  • 浙江网站建设费用适合员工的培训课程
  • 怎么塔建网站wordpress和lofter
  • 星空传媒有限公司网站个人网站开发教程
  • 厦门做网站seowordpress 提交评论
  • 衡水网站公司wordpress 微博图标
  • 微商城网站开发视频wordpress 更改用户名密码
  • 潮州专业网站建设报价网站安全建设的重要性
  • 模板建站是什么意思上海公司记账
  • 婚恋网站建设分析外贸优秀网站
  • 如何免费申请公司网站怎样把自己做的网站发到网上
  • 宣传网站站点最有效的方式是大连网站建设招标
  • 数字域名有哪些网站门户网站怎样做
  • 一个公司做多个网站是好还是坏手机网站预览
  • 一站式网站手机端怎么做廊坊seo排名霸屏
  • 公司网站建设的步骤wordpress缺点