解决AFN的post请求错误:Error Domain=NSCocoaErrorDomain Code=3840

Error Domain=NSCocoaErrorDomain Code=3840 "The operation couldn’t be completed. (Cocoa error 3840.)" (JSON text did not start with array or object and option to allow fragments not set.) UserInfo=0x9152780 {NSDebugDescription=JSON text did not start with array or object and option to allow fragments not set.}

今天用AFN给后台发post请求的时候报了这个错误,但后台确认我是请求成功的了,给我返回了成功的数据。

原因是后台给我返回的是字符串数据,我却以接收Json的形式发请求,

解决如下:(注释掉的是接收Json数据的(如果不设置,就是默认这个),下面那个是AFHTTPResponseSerializer才是能请求成功的

- (AFHTTPSessionManager *)manager

{

    if (!_manager) {

        _manager =  [AFHTTPSessionManager manager];

//        _manager.responseSerializer = [AFJSONResponseSerializer serializer];

        _manager.responseSerializer = [AFHTTPResponseSerializer serializer];

        _manager.responseSerializer.acceptableContentTypes = [NSSet setWithObject:@"text/html"];

        _manager.requestSerializer=[AFHTTPRequestSerializer serializer];

    }

    return _manager;

}

补充:请求成功后返回的字符串数据是Data类型(我接收到的是一串数字),所以需要转换一下为字符串方可使用如下。

            [self.manager POST:URLStr parameters:param progress:^(NSProgress * _Nonnull uploadProgress) {

            } success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {

                

                NSData *strData = responseObject;

                NSString *nameStr =  [[NSString alloc]initWithData:strData encoding:NSUTF8StringEncoding];



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的!下面是一个使用HTML和JavaScript的示例,可以在Eclipse中创建一个带有跨域功能的网页,根据输入的车牌号点击查询按钮,显示金额在页面上,并且使用自己的服务器端进行代理处理跨域请求: index.html: ```html <!DOCTYPE html> <html> <head> <title>查询车辆金额</title> <script src="script.js"></script> </head> <body> <h1>查询车辆金额</h1> <label for="truckNoInput">车牌号:</label> <input type="text" id="truckNoInput" /> <button onclick="queryAmount()">查询</button> <br><br> <div id="resultDiv"></div> </body> </html> ``` script.js: ```javascript function queryAmount() { var truckNo = document.getElementById("truckNoInput").value; var apiUrl = "http://localhost:8080/proxy/TruckParkTimeProxy?TruckNo=" + encodeURIComponent(truckNo); var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState === XMLHttpRequest.DONE) { if (xhr.status === 200) { var response = JSON.parse(xhr.responseText); var money = response.Money; var resultDiv = document.getElementById("resultDiv"); resultDiv.innerHTML = "车牌号:" + truckNo + "<br>金额:" + money; } else { console.log("请求失败"); } } }; xhr.open("GET", apiUrl, true); xhr.send(); } ``` 在这个示例中,我们创建了一个简单的HTML页面,并使用JavaScript来处理点击查询按钮的事件。当用户点击查询按钮时,JavaScript代码将通过发送一个HTTP GET请求到自己的服务器端来代理处理跨域请求。 接下来,我们需要在服务器端创建一个代理来转发请求并处理跨域问题。 首先,在Eclipse中创建一个Java Web项目,并在项目的src目录下创建一个名为`TruckParkTimeProxyServlet.java`的Servlet文件,内容如下: ```java import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class TruckParkTimeProxyServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String truckNo = request.getParameter("TruckNo"); String apiUrl = "http://10.198.8.102:8081/TruckParkTime?Token=Parking2023&TruckNo=" + truckNo; // 发送HTTP GET请求获取接口返回结果 URL url = new URL(apiUrl); HttpURLConnection connection = (HttpURLConnection) url.openConnection(); connection.setRequestMethod("GET"); int responseCode = connection.getResponseCode(); if (responseCode == HttpURLConnection.HTTP_OK) { BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream())); StringBuilder responseBuilder = new StringBuilder(); String line; while ((line = reader.readLine()) != null) { responseBuilder.append(line); } reader.close(); String apiResponse = responseBuilder.toString(); // 构建HTML响应 response.setContentType("application/json"); response.setCharacterEncoding("UTF-8"); response.getWriter().println(apiResponse); } else { // 处理请求失败的情况 response.setStatus(HttpServletResponse.SC_INTERNAL_SERVER_ERROR); } } } ``` 在这个Servlet中,我们接收来自前端的请求,并将请求转发到目标接口URL。然后,我们将接口返回的结果作为响应返回给前端。 接下来,在Web项目的`WEB-INF`目录下的`web.xml`文件中添加Servlet的配置: ```xml <web-app> <!-- 其他配置 --> <servlet> <servlet-name>TruckParkTimeProxyServlet</servlet-name> <servlet-class>com.example.TruckParkTimeProxyServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>TruckParkTimeProxyServlet</servlet-name> <url-pattern>/proxy/TruckParkTimeProxy</url-pattern> </servlet-mapping> <!-- 其他配置 --> </web-app> ``` 在这个配置中,我们将Servlet映射到`/proxy/TruckParkTimeProxy`路径上,以便前端通过这个路径来访问代理服务。 最后,您需要将整个项目部署到一个支持Java Servlet的Web服务器(如Tomcat)中。启动Web服务器后,在浏览器中访问`http://localhost:8080/your-web-project/index.html`来查看和测试这个网页。 请注意,使用代理服务来处理跨域请求是一种常见的解决方案。当然,实际部署时,您可能需要根据自己的需求和环境进行适当的调整和安全控制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值