react+Tesseract.js实现前端拍照获取/选择文件等文字识别OCR

需求背景

在开发过程中可能会存在用户上传一张图片后下方需要自己识别出来文字数字等信息,有的时候会通过后端来识别后返回,但是也会存在纯前端去识别的情况,这个时候就需要使用到Tesseract.js这个库了 附Tesseract.js官方(https://github.com/naptha/tesseract.js)

实现过程

主要的实现代码部分和这部分的简易效果图

javascript 复制代码
import {createWorker} from 'tesseract.js';

const worker = await createWorker();
await worker.loadLanguage('chi_sim');
await worker.initialize('chi_sim');
const { data: { text } } = await worker.recognize(myImage);
console.log(text);
await worker.terminate();

下方是一个简单的完整实现案例 ⬇

npm install tesseract.js

  1. createWorker创建worker实例。

  2. 调用worker.loadLanguage('chi_sim')。

  3. 调用worker.initialize('chi_sim')。

  4. 然后调用recognize方法进行识别。

javascript 复制代码
import React, { useState, useEffect } from 'react';
import { createWorker } from 'tesseract.js';

const OCRComponent = () => {
  const [image, setImage] = useState(null);
  const [text, setText] = useState('');
  const [progress, setProgress] = useState(0);
  const [error, setError] = useState('');
  const [worker, setWorker] = useState(null);

  // 初始化 Worker
  useEffect(() => {
    const initializeWorker = async () => {
      const newWorker = await createWorker();
      setWorker(newWorker);
    };
    initializeWorker();
    return () => {
      if (worker) {
        worker.terminate();
      }
    };
  }, []);

  // 处理图片上传
  const handleImageUpload = (e) => {
    const file = e.target.files[0];
    if (file) {
      const reader = new FileReader();
      reader.onloadend = () => {
        setImage(reader.result);
      };
      reader.readAsDataURL(file);
      setText('');
      setError('');
    }
  };

  // 执行 OCR 识别
  const recognizeText = async () => {
    if (!worker || !image) return;

    try {
      //chi_sim代表的是简体中文包  eng是英文  需要识别其他语言的话可以官网去看下对应的名称
      await worker.loadLanguage('chi_sim');
      await worker.initialize('chi_sim');
      const { data: { text } } = await worker.recognize(image, {
        logger: (m) => {
          if (m.status === 'recognizing text') {
            setProgress(Math.round(m.progress * 100));
          }
        }
      });
      setText(text);
    } catch (err) {
      setError('识别失败,请重试或更换图片。');
      console.error(err);
    } finally {
      await worker.terminate();
    }
  };

  return (
    <div>
      <h1>中文 OCR 文字识别</h1>
      
      {/* 文件上传 */}
      <input type="file" accept="image/*" onChange={handleImageUpload} />
      
      {/* 图片预览 */}
      {image && (
        <div>
          <h3>图片预览</h3>
          <img src={image} alt="预览" style={{ maxWidth: '100%', height: 'auto' }} />
        </div>
      )}

      {/* 识别按钮及进度 */}
      {image && (
        <div>
          <button onClick={recognizeText} disabled={progress > 0}>
            {progress > 0 ? `识别中... ${progress}%` : '开始识别'}
          </button>
        </div>
      )}

      {/* 显示结果 */}
      {text && (
        <div>
          <h3>识别结果</h3>
          <pre style={{ whiteSpace: 'pre-wrap' }}>{text}</pre>
        </div>
      )}

      {/* 错误提示 */}
      {error && <p style={{ color: 'red' }}>{error}</p>}
    </div>
  );
};

export default OCRComponent;
相关推荐
不会敲代码119 小时前
手写 Zustand:三十分钟带你搞懂状态管理库的核心原理
前端·javascript·源码
神奇的程序员19 小时前
重构了自己5年前写的截图插件
前端·javascript·架构
橙淮19 小时前
从优化到安全再到未来 ——JavaScript 全维度技术指南
javascript
UXbot21 小时前
一人独立交付 UI + 前端:AI 驱动 UI 设计工具的五大功能模块深度评测
前端·低代码·ui·设计模式·交互
kobesdu21 小时前
【ROS2实战笔记-19】ROS2 生命周期节点的启动顺序、状态转换陷阱与热备方案
java·前端·笔记·机器人·ros·ros2
诚实可靠王大锤21 小时前
React Native 输入框与按钮焦点冲突解决方案(rn版本0.70.3)
前端·javascript·react native·react.js
kyriewen21 小时前
测试妹子让我写单测,我偷偷用AI一天干完一周的活
前端·chatgpt·cursor
2601_9577808421 小时前
Claude Code 2026年最新部署指南:从环境搭建到技能扩展
前端·人工智能·ai编程·claude
zhangfeng11331 天前
workbuddy 专家 “前端开发师” 结合nvidia-mistral-small-4-119b-2603 项目计划-前端界面开发.md
前端·人工智能·免费
IT_陈寒1 天前
为什么Java的Stream并行处理反而变慢了?
前端·人工智能·后端