有关于JAVA与后端C应用UTF8字符的通信

 

后端有C写的服务程序,它只能接受UTF-8的字符串,并将响应
以UTF-8的形式送出。
JAVA连接该程序时,用CORBA哦
1、
直接定义字符串:
String str = "我是好人",时CORBA发出错误信息表示有不识别的字符
经过如下转换后
String newreq = new String(str.getBytes("UTF-8"),"ISO-8859-1");
将newreq送到服务端,后端得到了正确的UTF-8字符。
2、
同时,如果将服务端返回的UTF-8字符直接打印到控制台上,发现是乱码,
用以下方法:
localstr = new String(str.getBytes("ISO-8859-1"), "UTF-8");
localstr打出了正常的字符

写这个小文章并不想说明什么,主要是因为前端时间看到类似的文章,比如,
告诉你:String str = new String(str.getBytes("ISO-8859-1"),"UTF-8")就能
得到UTF-8字符,这种说法是片面的,关键是看字符本身的编码是什么才是最重要的。

象在第二步中,为什么拿回来的UTF-8打印不出来,非得象上面处理过后才行呢?
主要是JAVA收到串后认为它是ISO-8859-1,但实际通过它得到的BYTE序列应该用
UTF-8解码才是正确的

以下是使用Java实现微信支付后端代码的示例: 1. 创建统一下单请求对象 ```java public class UnifiedOrderRequest { private String appid; // 公众账号ID private String mch_id; // 商户号 private String nonce_str; // 随机字符串 private String body; // 商品描述 private String out_trade_no; // 商户订单号 private int total_fee; // 标价金额,单位为分 private String spbill_create_ip; // 终端IP private String notify_url; // 通知地址 private String trade_type; // 交易类型 private String openid; // 用户标识 // 省略 getter 和 setter 方法 } ``` 2. 创建统一下单响应对象 ```java public class UnifiedOrderResponse { private String return_code; // 返回状态码 private String return_msg; // 返回信息 private String appid; // 公众账号ID private String mch_id; // 商户号 private String nonce_str; // 随机字符串 private String sign; // 签名 private String result_code; // 业务结果 private String prepay_id; // 预支付交易会话标识 private String trade_type; // 交易类型 private String code_url; // 二维码链接 // 省略 getter 和 setter 方法 } ``` 3. 发送统一下单请求 ```java public class WechatPayService { private static final String UNIFIED_ORDER_URL = "https://api.mch.weixin.qq.com/pay/unifiedorder"; public UnifiedOrderResponse unifiedOrder(UnifiedOrderRequest request) throws Exception { String xml = buildUnifiedOrderXml(request); String responseXml = postXml(UNIFIED_ORDER_URL, xml); return parseUnifiedOrderXml(responseXml); } private String buildUnifiedOrderXml(UnifiedOrderRequest request) throws Exception { Map<String, Object> data = new HashMap<>(); data.put("appid", request.getAppid()); data.put("mch_id", request.getMch_id()); data.put("nonce_str", request.getNonce_str()); data.put("body", request.getBody()); data.put("out_trade_no", request.getOut_trade_no()); data.put("total_fee", request.getTotal_fee()); data.put("spbill_create_ip", request.getSpbill_create_ip()); data.put("notify_url", request.getNotify_url()); data.put("trade_type", request.getTrade_type()); data.put("openid", request.getOpenid()); data.put("sign", WechatPayUtil.sign(data, "商户密钥")); return WechatPayUtil.mapToXml(data); } private UnifiedOrderResponse parseUnifiedOrderXml(String xml) throws Exception { Map<String, String> data = WechatPayUtil.xmlToMap(xml); UnifiedOrderResponse response = new UnifiedOrderResponse(); response.setReturn_code(data.get("return_code")); response.setReturn_msg(data.get("return_msg")); response.setAppid(data.get("appid")); response.setMch_id(data.get("mch_id")); response.setNonce_str(data.get("nonce_str")); response.setSign(data.get("sign")); response.setResult_code(data.get("result_code")); response.setPrepay_id(data.get("prepay_id")); response.setTrade_type(data.get("trade_type")); response.setCode_url(data.get("code_url")); return response; } private String postXml(String url, String xml) throws Exception { HttpClient httpClient = HttpClients.createDefault(); HttpPost httpPost = new HttpPost(url); httpPost.setEntity(new StringEntity(xml, ContentType.APPLICATION_XML)); HttpResponse response = httpClient.execute(httpPost); HttpEntity entity = response.getEntity(); String responseXml = EntityUtils.toString(entity); EntityUtils.consume(entity); return responseXml; } } ``` 4. 处理支付结果通知 ```java public class WechatPayNotifyService { public void handleNotify(HttpServletRequest request, HttpServletResponse response, String merchantKey) throws Exception { String xml = IOUtils.toString(request.getInputStream(), StandardCharsets.UTF_8); Map<String, String> data = WechatPayUtil.xmlToMap(xml); if (WechatPayUtil.verifySign(data, merchantKey)) { if ("SUCCESS".equals(data.get("return_code")) && "SUCCESS".equals(data.get("result_code"))) { // 支付成功,处理业务逻辑 } String responseXml = buildNotifyResponseXml("SUCCESS", "OK"); response.getWriter().write(responseXml); } else { String responseXml = buildNotifyResponseXml("FAIL", "签名验证失败"); response.getWriter().write(responseXml); } } private String buildNotifyResponseXml(String returnCode, String returnMsg) { Map<String, String> data = new HashMap<>(); data.put("return_code", returnCode); data.put("return_msg", returnMsg); return WechatPayUtil.mapToXml(data); } } ``` 以上代码仅为示例,实际使用时需要根据具体业务需求进行适当调整。同时,为了确保交易的安全性,建议使用 HTTPS 协议进行通信,并对敏感信息进行加密处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值