gpt4 book ai didi

java - 如何获取数据库表数据(oracle 11g)作为Json对象并在Android中显示该Json对象?

转载 作者:行者123 更新时间:2023-12-01 11:23:10 25 4
gpt4 key购买 nike

我正在尝试在 Android 应用程序和 Oracle DB 之间创建连接。我发现我必须创建一个 Web 服务,所以我开始编写一个 servlet,它将创建与数据库的连接并将数据作为 JSON 对象返回,该对象可以在 android 上解析。
首先,我编写了一个 servlet 来返回 HTML 格式的数据,这非常简单,以下是我的 servlet 代码

package a.b.c;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class ServletDatabaseConnect extends HttpServlet
{
protected void doPost(HttpServletRequest req,HttpServletResponse res)throws ServletException,IOException
{
PrintWriter pw=res.getWriter();
res.setContentType("text/html");
String tb=req.getParameter("table");

try
{
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection con=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE","system","admin");
Statement st=con.createStatement();
System.out.println("connection established successfully...!!");

ResultSet rs=st.executeQuery("Select * from "+tb);

pw.println("<table border=1>");
while(rs.next())
{
pw.println("<tr><td>"+rs.getInt(1)+"</td><td>"+rs.getString(2)+"</td>"+
"<td>"+rs.getString(3)+"</td></tr>");
}
pw.println("</table>");
pw.close();
}
catch (Exception e){
e.printStackTrace();
}

}
}

如何修改 servlet 代码以返回 JSON 对象格式的数据?

最佳答案

您必须使用 Jackson 将您的信息转换为 json 格式,此操作称为序列化,Jackson 是完成此任务的完美工具,您可以查看一些示例 here

关于java - 如何获取数据库表数据(oracle 11g)作为Json对象并在Android中显示该Json对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31029763/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com