增值税发票核验API在Java、Python、PHP中的使用教程

在这里插入图片描述
在企业经营中,发票扮演着记录交易、报销和纳税的重要角色。然而,由于发票的众多类型和复杂的制作方式,一些企业可能面临着假发票、冒充发票等风险。为了提高财务管理的效率和准确性,以及防范不法行为,增值税发票核验成为财务管理中的一项必备步骤。

什么是增值税发票核验API?
增值税发票核验API是一种通过编程方式访问和使用增值税发票核验服务的接口。这类API通常由专业的财务服务提供商提供,允许开发者将增值税发票核验功能集成到其财务系统、企业应用程序或网站中。这样的API能够快速、准确地验证一张发票的真实性,避免使用伪造或无效的发票。

增值税发票核验API适用于哪些人?

  1. 企业财务团队: 用于验证公司开具的和收到的增值税发票,确保财务数据的准确性和合规性。

  2. 会计事务所: 用于辅助客户进行增值税报表的制作,提高会计服务的效率和质量。

  3. 税务机关: 用于对纳税企业的增值税发票进行验证,确保企业按规定报税。

  4. 金融机构: 用于贷后管理中验证客户提供的增值税发票,降低信贷风险。

  5. 企业软件开发者: 用于集成到企业财务软件中,为用户提供方便的增值税发票核验功能。

增值税发票核验API是如何工作的?

  1. 图像采集: 用户通过扫描仪、相机或手机拍摄发票图像,然后将图像上传至增值税发票核验API。

  2. 图像预处理: 对上传的图像进行处理,包括去除噪声、调整图像质量,确保后续的分析能够基于高质量的图像进行。

  3. 发票信息提取: API通过光学字符识别(OCR)等技术,从发票图像中提取必要的信息,如发票号码、日期、金额等。

  4. 信息比对: 提取的发票信息与相应的税务数据库进行比对,验证发票的真实性和合法性。

  5. 结果返回: API将验证结果返回给用户,通常包括验证通过与否的标志,以及详细的验证信息。

如何使用增值税发票核验API?

  1. 注册和获取API密钥: 开发者需要在提供增值税发票核验API的平台注册账户,并获取API密钥,以便进行身份验证和访问API服务。

  2. 集成到应用程序: 开发者根据API提供的文档和示例代码,将增值税发票核验API集成到自己的应用程序或系统中。

  3. 图像上传: 用户通过应用程序上传需要验证的增值税发票图像,确保图像清晰可见。

  4. 获取验证结果: 应用程序通过API调用获取增值税发票核验的结果,根据结果决定是否接受或拒绝该发票。

  5. 定期更新: 开发者需要定期检查API提供商是否有更新,以确保使用的是最新版本的增值税发票核验API。

通过使用增值税发票核验API,企业和组织可以提高财务管理的效率,减少因使用无效或伪造发票而带来的风险。这项技术为各行各业提供了更加便捷和可靠的增值税发票核验解决方案,助力数字化时代财务管理的发展。

增值税发票核验在不同开发语言中的调用(Java/python/php 示例)
在Java中,下面这段代码展示了如何使用 Java 发送 HTTP POST 请求到人脸对比服务,以及如何处理服务的响应。需要注意的是,其中的 HttpUtils 类和依赖项需要从提供的链接下载并引入。此外,{{AppCode}} 部分需要替换为实际的应用程序代码。

import com.mittang.util.HttpUtils;
import org.apache.http.HttpResponse;
import org.apache.http.util.EntityUtils;
import java.util.HashMap;
import java.util.Map;

public class Example {
    public static void main(String[] args) throws Exception{
        String host = "https://open.expauth.com";
        String path = "/v1/tools/ocr/verInvoice";
        String method = "POST";
        // "{{AppCode}}" 替换成您的 AppCode
        String appcode = "{{AppCode}}";
        Map headers = new HashMap<>();
        headers.put("X-Mce-Signature", "AppCode/" + appcode);
        headers.put("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
        Map querys = new HashMap<>();
        Map bodys = new HashMap<>();
        // 填充参数
        bodys.put("invoiceCode", "invoiceCode");
        bodys.put("invoiceNumber", "invoiceNumber");
        bodys.put("billingDate", "billingDate");
        bodys.put("totalAmount", "totalAmount");
        bodys.put("checkCode", "checkCode");
        bodys.put("invoiceType", "invoiceType");

        try {
            /**
             * 重要提示如下:
             * HttpUtils请从
             * https://static.miitang.com/saas/simple/HttpUtils.java 下载
             *
             * 相应的依赖请参照
             * https://static.miitang.com/saas/simple/pom.xml
             */
            HttpResponse response = HttpUtils.doPost(host, path, method, headers, querys, bodys);
            // 获取 response 的 body
            String resStr = EntityUtils.toString(response.getEntity());
            System.out.println(resStr);
            int statusCode = response.getStatusLine().getStatusCode();
            if(statusCode == 200){
                // 请求成功,可根据业务码(请求体中的code)进行逻辑处理
            } else if(statusCode == 610){
                // 用户输入的参数问题,可直接提示用户
            } else if(statusCode == 611){
                // 系统准备的数据问题,如 文件数据下载失败、数据不存在、数据重复请求等。  LOG it and 提示用户
            } else if(statusCode == 612){
                // 用户操作频度问题,可提示用户。  LOG it and 按业务特点做处理
            } else if(statusCode >= 500 && statusCode < 600){
                // 在运行阶段发生的系统稳定性问题,客户端可以重试,或者联系我司客服
            } else {
                // 如账户密码错误、IP白名单问题、余额不足等,您应该在对接过程中解决相关问题。
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

在Python中,使用 requests 库发送 POST 请求到增值税发票核验服务接口,根据响应状态码进行业务逻辑处理,包括成功、参数问题、数据问题、操作频度问题和系统稳定性问题等的处理。

import json
import requests


if __name__ == '__main__':

    url = "https://open.expauth.com/v1/tools/ocr/verInvoice"

    payload = json.dumps({
        "invoiceCode": "invoiceCode",
        "invoiceNumber": "invoiceNumber",
        "billingDate": "billingDate",
        "totalAmount": "totalAmount",
        "checkCode": "checkCode",
        "invoiceType": "invoiceType"
    })

    headers = {
        "Content-Type": "application/json",
        # "{{AppCode}}" 替换为您的 AppCode
        "X-Mce-Signature": "AppCode/{{AppCode}}"
    }

    response = requests.request("POST", url, headers=headers, data=payload)
    status_code = response.status_code
    print("headers:", response.headers)
    print("http 状态码:", str(status_code))
    print(response.text)
    if status_code == 200:
         "请求成功,可根据业务码(请求体中的code)进行逻辑处理"
    elif status_code == 610 :
         "用户输入的参数问题,可直接提示用户"
    elif status_code == 611 :
         "系统准备的数据问题,如 文件数据下载失败、数据不存在、数据重复请求等。  LOG it and 提示用户"
    elif status_code == 612 :
        "用户操作频度问题,可提示用户。  LOG it and 按业务特点做处理"
    elif status_code >= 500 & status_code < 600 :
         "在运行阶段发生的系统稳定性问题,客户端可以重试,或者联系我司客服"
    else:
         "如账户密码错误、IP白名单问题、余额不足等,您应该在对接过程中解决相关问题。"

在PHP中,使用 cURL 发送 POST 请求到增值税发票核验服务接口,处理并输出相应的业务逻辑。它包括设置请求头、发送请求、处理响应,根据响应状态码进行不同的业务逻辑处理,如成功、参数问题、数据问题、操作频度问题、系统稳定性问题等。

<?php
    $host = "https://open.expauth.com";
    $path = "/v1/tools/ocr/verInvoice";
    $method = "POST";
    $appcode = "{{您的AppCode}}";
    $headers = array();
    array_push($headers, "x-mce-signature:AppCode/" . $appcode);
    //根据API的要求,定义相对应的Content-Type
    array_push($headers, "Content-Type".":"."application/x-www-form-urlencoded; charset=UTF-8");
    $querys = "";
    $bodys = "invoiceCode=invoiceCode&invoiceNumber=invoiceNumber&billingDate=billingDate&totalAmount=totalAmount&checkCode=checkCode&invoiceType=invoiceType";
    $url = $host . $path;

    $curl = curl_init();
    curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $method);
    curl_setopt($curl, CURLOPT_URL, $url);
    curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
    curl_setopt($curl, CURLOPT_FAILONERROR, false);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($curl, CURLOPT_HEADER, true);
    if (1 == strpos("$".$host, "https://"))
    {
        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
    }
    curl_setopt($curl, CURLOPT_POSTFIELDS, $bodys);
    $result = curl_exec($curl);

    $header_size = curl_getinfo($curl, CURLINFO_HEADER_SIZE); // 获得响应头大小
    $httpCode = curl_getinfo($curl,CURLINFO_HTTP_CODE);
    $body = substr($result,$header_size);

    curl_close($curl);
    $retMap = json_decode($body, true);
    $code = $retMap["code"];


    echo $httpCode.PHP_EOL; // DEBUG

    if($httpCode == 200){
        // 请求成功,可根据业务码(请求体中的code)进行逻辑处理
        echo $retMap["code"].PHP_EOL;
        echo $retMap["message"].PHP_EOL;
        echo $retMap["hasFees"].PHP_EOL;
        echo $retMap["fees"].PHP_EOL;
        if($code == "FP00000"){
            // SUCCESS
            echo "SUCCESS";
        }
        else{
            // FAILURE
            echo "FAILURE";
        }
    } else {
        echo $code.PHP_EOL; // DEBUG

        if($httpCode == 610){
            // 用户输入的参数问题,可直接提示用户
            $errors = $retMap["errors"];
            $errorMap = null;
            foreach($errors as $key=>$value){
                foreach($value as $key2=>$value2){
                  $errorMap[$key] = $value2;
                  break;
                }
            }
            // 转化为 key:tip
            echo($errorMap["idCardNo"].PHP_EOL);
            echo($errorMap["name"].PHP_EOL);
        } else if($httpCode == 611){
            // 系统准备的数据问题,如 文件数据下载失败、数据不存在、数据重复请求等。  LOG it and 提示用户
            echo "修订数据状态,不要重复操作。".PHP_EOL;
        } else if($httpCode == 612){
            // 用户操作频度问题,可提示用户。  LOG it and 按业务特点做处理
            echo $retMap["message"].PHP_EOL;
        } else if($httpCode >= 500 && $httpCode < 600){
            // 在运行阶段发生的系统稳定性问题,客户端可以重试,或者联系我司客服
            // TODO: retry
            echo "RETRY".PHP_EOL;
        } else {
            // 如账户密码错误、IP白名单问题、余额不足等,您应该在对接过程中解决相关问题。
            var_dump($retMap);
        }
    }
?>

更多增值税发票核验相关API

增值税发票OCR识别

增值税发票(卷票)识别【API Space】

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/843323.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

定制QCustomPlot 带有ListView的QCustomPlot 全网唯一份

定制QCustomPlot 带有ListView的QCustomPlot 文章目录 定制QCustomPlot 带有ListView的QCustomPlot摘要需求描述实现关键字: Qt、 QCustomPlot、 魔改、 定制、 控件 摘要 先上效果,是你想要的,再看下面的分解,顺便点赞搜藏一下;不是直接右上角。 QCustomPlot是一款…

Jenkins-zookeeper-docker-xxljob-rancher

文章目录 Jenkins实战1 新建任务需要的配置pipeline Zookeeper基础 Docker基础实操windows11 docker mysql DockerhouseDockerhubxxl-Job基础实战 Rancher基础思考 实战1 Rancher的某个namespace的scale为0 Jenkins 实战 1 新建任务需要的配置pipeline 该代码是Jenkinsfile&…

【接口自动化_08课_Pytest+Yaml+Allure框架】

上节课一些内容 的补充 1、openxl这个方法&#xff0c;第一个元素是从1开始的&#xff0c;不是从0开始 回写的列在程序里写的是11&#xff0c;是因为是固定值 一、1. Yaml入门及应用 1、什么是yaml YAML&#xff08;/ˈjməl/&#xff0c;尾音类似camel骆驼&#xff09;是一…

探索Python日志管理的优雅之道:Loguru库入门指南

探索Python日志管理的优雅之道&#xff1a;Loguru库入门指南 背景&#xff1a;为何选择Loguru&#xff1f; 在Python开发过程中&#xff0c;日志记录是不可或缺的一部分&#xff0c;它帮助我们追踪程序的运行状态&#xff0c;调试程序错误&#xff0c;并记录关键信息。然而&am…

【Linux】-----权限详解

目录 一、Linux下的权限概念 Ⅰ、是什么&#xff1f; Ⅱ、Linux下的两种角色 角色 如何添加普通用户 身份的转化方式 身份的提权 添加普通用户至白名单 二、Linux下的权限管理 Ⅰ、文件访问者的分类(Linux下的“人”) Ⅱ、文件类型和访问权限(事物属性) 1.文件类型 …

使用AOP优化Spring Boot Controller参数:自动填充常用字段的技巧

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 &#x1f38f;&#xff1a;你只管努力&#xff0c;剩下的交给时间 &#x1f3e0; &#xff1a;小破站 使用AOP优化Spring Boot Controller参数&#xff1a;自动填充常用字段的技巧 前言为什么使用AOP为…

2-41 基于matlab的小车倒立摆系统的控制及GUI动画演示

基于matlab的小车倒立摆系统的控制及GUI动画演示。输入小车及倒立摆的初始参数&#xff0c;位置参数&#xff0c;对仿真时间和步长进行设置&#xff0c;通过LQR计算K值&#xff0c;进行角度、角速度、位置、速度仿真及曲线输出&#xff0c;程序已调通&#xff0c;可直接运行。 …

昇思MindSpore学习总结十七 —— 基于MindSpore通过GPT实现情感分类

1、要求 2、导入了一些必要的库和模块 以便在使用MindSpore和MindNLP进行深度学习任务时能使用各种功能&#xff0c;比如数据集处理、模型训练、评估和回调功能。 import os # 导入操作系统相关功能的模块&#xff0c;如文件和目录操作import mindspore # 导入MindSpore库&a…

HTTPServer改进思路2(mudou库核心思想融入)

mudou网络库思想理解 Reactor与多线程 服务器构建过程中&#xff0c;不仅仅使用一个Reactor&#xff0c;而是使用多个Reactor&#xff0c;每个Reactor执行自己专属的任务&#xff0c;从而提高响应效率。 首先Reactor是一种事件驱动处理模式&#xff0c;其主要通过IO多路复用…

基于WebGoat平台的SQL注入攻击

目录 引言 一、安装好JAVA 二、下载并运行WebGoat 三、注册并登录WebGoat 四、模拟攻击 1. 第九题 2. 第十题 3. 第十一题 4. 第十二题 5. 第十三题 五、思考体会 1. 举例说明SQL 注入攻击发生的原因。 2. 从信息的CIA 三要素&#xff08;机密性、完整性、可用性&…

JAVA:Filer过滤器+案例:请求IP访问限制和请求返回值修改

JAVA&#xff1a;Filer过滤器 介绍 Java中的Filter也被称为过滤器&#xff0c;它是Servlet技术的一部分&#xff0c;用于在web服务器上拦截请求和响应&#xff0c;以检查或转换其内容。 Filter的urlPatterns可以过滤特定地址http的请求&#xff0c;也可以利用Filter对访问请求…

[数据分析]脑图像处理工具

###############ATTENTION&#xff01;############### 非常需要注意软件适配的操作系统&#xff01;有些仅适用于Linux&#xff0c;可以点进各自软件手册查看详情。 需要自行查看支持的影像模态。 代码库和软件我没有加以区分。 不是专门预处理的博客&#xff01;&#xf…

Richteck立锜科技电源管理芯片简介及器件选择指南

一、电源管理简介 电源管理组件的选择和应用本身的电源输入和输出条件是高度关联的。 输入电源是交流或直流&#xff1f;需求的输出电压比输入电压高或是低&#xff1f;负载电流多大&#xff1f;系统是否对噪讯非常敏感&#xff1f;也许系统需要的是恒流而不是稳压 (例如 LED…

Mac装虚拟机占内存吗 Mac用虚拟机装Windows流畅吗

如今&#xff0c;越来越多的Mac用户选择在他们的设备上安装虚拟机来运行不同的操作系统。其中&#xff0c;最常见的是使用虚拟机在Mac上运行Windows。然而&#xff0c;许多人担心在Mac上装虚拟机会占用大量内存&#xff0c;影响电脑系统性能。此外&#xff0c;有些用户还关心在…

k8s中部署nacos

1 部署nfs # 在k8s的主节点上执行 mkdir -p /appdata/download cd /appdata/download git clone https://github.com/nacos-group/nacos-k8s.git 将nacos部署到middleware的命名空间中 kubectl create namespace middleware cd /appdata/download/nacos-k8s # 创建角色 kub…

图论模型-迪杰斯特拉算法和贝尔曼福特算法★★★★

该博客为个人学习清风建模的学习笔记&#xff0c;部分课程可以在B站&#xff1a;【强烈推荐】清风&#xff1a;数学建模算法、编程和写作培训的视频课程以及Matlab等软件教学_哔哩哔哩_bilibili 目录 ​1图论基础 1.1概念 1.2在线绘图 1.2.1网站 1.2.2MATLAB 1.3无向图的…

ABAP打印WORD的解决方案

客户要求按照固定格式输出到WORD模板中&#xff0c;目前OLE和DOI研究了均不太适合用于这种需求。 cl_docx_document类可以将WORD转化为XML文件&#xff0c;利用替换字符串方法将文档内容进行填充同 时不破坏WORD现有格式。 首先需要将WORD的单元格用各种预定义的字符进行填充…

canvas:矢量点转栅格

案例描述 ArcGIS提供了“点转栅格”的工具,可以将矢量点转换为栅格数据,以下尝试基于canvas绘图技术,实现经纬度矢量点转换为canvas栅格数据,并在Cesium.js三维地图中进行渲染。 原始数据 转出栅格 案例分析 实现的关键点在于:如何将经纬度坐标与canvas画布坐标进…

【Vue3】工程创建及目录说明

【Vue3】工程创建及目录说明 背景简介开发环境开发步骤及源码 背景 随着年龄的增长&#xff0c;很多曾经烂熟于心的技术原理已被岁月摩擦得愈发模糊起来&#xff0c;技术出身的人总是很难放下一些执念&#xff0c;遂将这些知识整理成文&#xff0c;以纪念曾经努力学习奋斗的日…

Figma 中文版指南:获取和安装汉化插件

Figma是一种主流的在线团队合作设计工具&#xff0c;也是一种基于 Web 端的设计工具。在当今的设计时代&#xff0c;Figma 的使用满足了每个人的设计需求&#xff0c;不仅可以实现在线编辑&#xff0c;还可以方便日常管理&#xff0c;有效提高工作效率。然而&#xff0c;相信很…