Mysql
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Mysql

JSON đang hiển thị lỗi 403 khi cố gắng tìm nạp dữ liệu từ cơ sở dữ liệu trong Android

Lấy một gợi ý từ bài đăng này , Tôi nghĩ bạn có thể cần đặt User-Agent trong yêu cầu JSON của bạn. Thử thêm một dòng trong JSONFunction.makeHttpRequest() trước khi gọi đến execute() như:

httpPost.setHeader("User-Agent","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.2357.81 Safari/537.36");

hoặc trên dòng trước khi gọi setEntity() bạn có thể làm điều gì đó như:

para.add(new NameValuePair("User-Agent","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.2357.81 Safari/537.36"));

(Lưu ý:chuỗi tác nhân người dùng này chỉ là một chuỗi mà tôi lấy từ trình duyệt của mình. Bạn có thể sử dụng một chuỗi từ bất kỳ trình duyệt hiện đại nào.)

Điều này sẽ làm cho dịch vụ REST của bạn tin rằng yêu cầu đến từ trình duyệt web. Tôi nghi ngờ rằng đó là nguyên nhân có thể gây ra lỗi 403, tức là máy chủ web của bạn không biết loại tác nhân mà yêu cầu đến từ. Về lý do tại sao nó chỉ ngừng hoạt động, có lẽ máy chủ nơi dịch vụ PHP của bạn đang chạy đã được cập nhật gần đây để nó không chấp nhận các yêu cầu mà tác nhân người dùng không được khai báo.




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. bash - Kết quả truy vấn SQL thành biến

  2. Nhận câu lệnh SQL sau khi các tham số được thêm vào

  3. Bộ nhớ đệm của PreparedStatement - nghĩa là gì (nó hoạt động như thế nào)

  4. Cách chọn cho đến khi đạt được tổng

  5. Sử dụng Liên minh hoặc Tham gia - Điều gì nhanh hơn