0

0

如何在 GeneXus 17 中通过 HTTP 请求正确上传 XML 文件

聖光之護

聖光之護

发布时间:2026-02-02 17:56:02

|

432人浏览过

|

来源于php中文网

原创

如何在 GeneXus 17 中通过 HTTP 请求正确上传 XML 文件

本文详解 genexus 17(java 环境)中使用 `httpclient` 上传 xml 文件的正确方法,重点纠正路径写法与参数顺序错误,并提供可直接运行的代码示例和关键注意事项。

在 GeneXus 17 的 Java Web 应用中,通过 HttpClient 向外部 API 上传 XML 文件是常见需求,但开发者常因对象初始化、路径格式或方法调用顺序问题遭遇运行时异常——最典型的是 “Object reference not set to an instance of an object”(即 Java 中的 NullPointerException)。该错误并非源于网络或权限,而是因 HttpClient 实例未正确创建,或 AddFile() 方法参数传入顺序错误所致。

✅ 正确做法:参数顺序 + 路径规范 + 实例初始化

首先,务必确保 &HttpClient 已正确定义并实例化:

&HttpClient = new HttpClient()

其次,关键修正点在于 AddFile() 方法的参数顺序:GeneXus 17 Java 版本要求第一个参数为 文件本地路径(String),第二个参数为 表单字段名(field name),与部分文档或直觉相反。你原代码中写为:

稿定AI社区
稿定AI社区

在线AI创意灵感社区

下载
&HttpClient.AddFile('file','.\dadosConciliadora_27-01-2023_09h24m09s697ms.xml')  // ❌ 错误顺序

这会导致内部解析失败,进而触发空引用异常。正确写法应为:

&HttpClient.AddFile('.\dadosConciliadora_27-01-2023_09h24m09s697ms.xml', 'file')  // ✅ 路径在前,字段名在后
? 注意路径写法: 使用 .\ 表示当前工作目录(推荐),避免绝对路径依赖; 若文件位于 KB 部署目录外(如 C:\temp\),请使用完整路径(如 "C:\\temp\\dadosConciliadora_27-01-2023_09h24m09s697ms.xml"),注意双反斜杠转义; 不支持 Unix 风格斜杠 / 在 Windows Java 环境中作为路径分隔符(虽部分场景兼容,但不保证稳定)。

✅ 完整可运行示例(含认证与头信息)

Event 'SendXMLToAPI'
   &HttpClient = new HttpClient()

   // 设置请求头(multipart/form-data 由 AddFile 自动设置,无需手动指定)
   &HttpClient.AddHeader("Accept", "application/json")

   // 添加表单字段(非文件参数)
   &HttpClient.AddVariable("idEmpresa", "123")
   &HttpClient.AddVariable("senha", "abcdfg")

   // ✅ 关键:AddFile(本地文件路径, 表单字段名)
   &HttpClient.AddFile(".\dadosConciliadora_27-01-2023_09h24m09s697ms.xml", "file")

   // 执行 POST(自动构建 multipart body)
   &Result = &HttpClient.Execute(HttpMethod.Post, &url)

   If &Result.StatusCode = 200
      Msg("Upload successful: " + &Result.ToString())
   Else
      Msg("Error " + &Result.StatusCode + ": " + &Result.StatusDescription)
   EndIf
EndEvent

⚠️ 重要注意事项

  • 不要手动设置 Content-Type: multipart/form-data:AddFile() 内部会自动构造边界(boundary)并设置正确的 Content-Type 头。手动添加反而可能破坏 multipart 结构,导致服务端解析失败。
  • AddVariable() 与 AddFile() 可混合调用:GeneXus 会统一打包为 multipart body,字段顺序不影响服务端接收(只要字段名匹配 API 文档)。
  • 文件必须存在于服务器端(Java 运行环境)路径中:GeneXus 生成的 Java 应用运行在 Tomcat/Jetty 上,.\ 指向的是应用服务器的工作目录(通常是 tomcat/bin/ 或 webapps/ROOT/),建议将 XML 文件部署到 webapps/ROOT/ 下或使用绝对路径确保可访问。
  • 调试建议:启用 HttpClient.LogEnabled = True 并检查日志输出,确认是否成功读取文件及发送完整 multipart 请求体。

掌握这一细节,即可稳定实现 XML 文件上传,避免因底层对象未初始化或参数错位引发的隐蔽崩溃。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
如何配置Tomcat环境变量
如何配置Tomcat环境变量

配置Tomcat环境变量需要在系统中添加CATALINA_HOME变量,并将Tomcat的安装路径添加到PATH变量中。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

114

2023.10.26

idea如何集成Tomcat
idea如何集成Tomcat

idea集成Tomcat的步骤:1、添加Tomcat服务器配置;2、配置项目部署;3、运行Tomcat服务器;4、访问项目;5、注意事项;6、关闭Tomcat服务器。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

169

2024.02.23

怎么查看Tomcat源代码
怎么查看Tomcat源代码

查看Tomcat源代码的步骤:1、下载Tomcat源代码;2、在IDEA中导入Tomcat源代码;3、查看源代码;4、理解Tomcat的工作原理;5、参与社区和贡献;6、注意事项;7、持续学习和更新;8、使用工具和插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

98

2024.02.23

常见的tomcat漏洞有哪些
常见的tomcat漏洞有哪些

常见的tomcat漏洞有:1、跨站脚本攻击;2、跨站请求伪造;3、目录遍历漏洞;4、缓冲区溢出漏洞;5、配置漏洞;6、第三方组件漏洞。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

164

2024.02.23

tomcat日志乱码怎么解决
tomcat日志乱码怎么解决

tomcat日志乱码的解决办法:1、修改tomcat的日志编码设置;2、检查ide的编码设置;3、检查操作系统的编码设置;4、使用过滤器处理日志;5、检查外部系统的编码设置;6、检查文件编码方式等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

151

2024.02.23

weblogic和tomcat有哪些区别
weblogic和tomcat有哪些区别

weblogic和tomcat的区别:1、功能;2、性能;3、规模;4、价格;5、安全性;6、配置和管理;7、社区支持;8、集成能力;9、升级和更新;10、可靠性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

198

2024.02.23

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

235

2024.02.23

tomcat启动闪退怎么解决
tomcat启动闪退怎么解决

tomcat启动闪退的解决办法:1、检查java环境;2、检查环境变量配置;3、检查端口被占用;4、检查配置文件编码;5、检查启动时需要的配置文件;6、检查相关文件是否丢失;7、检查防火墙和杀毒软件设置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

162

2024.02.23

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

53

2026.02.02

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.1万人学习

C# 教程
C# 教程

共94课时 | 8.3万人学习

Java 教程
Java 教程

共578课时 | 55.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号