使用GSON和Java的完整RESTFUL WebService

时间:2015-01-14 19:02:40

标签: java json web-services rest sapui5

我创建了一个RESTFUL web服务,女巫返回一个json,但此时我只咨询并显示一个简单的选择*,我需要创建一个完整的CRUD解决方案,如果有人有一些样本要分享,我'我会很感激。

最好的问候

我的代码到现在为止:

DAO - Access.java

package dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;

import dto.Usuarios;

public class Access
{
    public ArrayList<Usuarios> getUsuarios(Connection con) throws SQLException
    {
        ArrayList<Usuarios> usuariosList = new ArrayList<Usuarios>();
        PreparedStatement stmt = con.prepareStatement("SELECT * FROM usuarios");
        ResultSet rs = stmt.executeQuery();
        try
        {
            while(rs.next())
            {
                Usuarios usuariosObj = new Usuarios();
                usuariosObj.setUsr_id(rs.getInt("usr_id"));
                usuariosObj.setUsr_login(rs.getString("usr_login"));
                usuariosObj.setUsr_pwd(rs.getString("usr_pwd"));
                usuariosList.add(usuariosObj);

            }
        } catch (SQLException e)
        {       
            e.printStackTrace();
        }
        return usuariosList;

    }
}

DTO - Usuarios.java

package dto;

public class Usuarios
{
    private int usr_id;
    private String usr_login;
    private String usr_pwd;

    public Usuarios()
    {

    }

    public Usuarios(int usr_id, String usr_login, String usr_pwd)
    {
        super();
        this.usr_id = usr_id;
        this.usr_login = usr_login;
        this.usr_pwd = usr_pwd;
    }

    public int getUsr_id()
    {
        return usr_id;
    }

    public void setUsr_id(int usr_id)
    {
        this.usr_id = usr_id;
    }

    public String getUsr_login()
    {
        return usr_login;
    }

    public void setUsr_login(String usr_login)
    {
        this.usr_login = usr_login;
    }

    public String getUsr_pwd()
    {
        return usr_pwd;
    }

    public void setUsr_pwd(String usr_pwd)
    {
        this.usr_pwd = usr_pwd;
    }


    @Override
    public String toString()
    {
        return "[ {usr_id=" + usr_id + ", usr_login=" + usr_login + ", usr_pwd=" + usr_pwd + "} ]";
    }

}

模型 - AccessManager.java

package model;

import java.sql.Connection;
import java.sql.SQLException;
import java.util.ArrayList;

import dao.Access;
import dao.Database;
import dto.Usuarios;

public class AccessManager
{
    public ArrayList<Usuarios> getUsuarios() throws Exception
    {
        ArrayList<Usuarios> usuariosList = new ArrayList<Usuarios>();
        Database db = new Database();
        Connection con = db.getConnection();
        Access access = new Access();
        usuariosList = access.getUsuarios(con);
        return usuariosList;
    }
}

WebService - UsuariosService.java

package webService;

import java.util.ArrayList;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;

import com.google.gson.Gson;

import model.AccessManager;
import dto.Usuarios;

@Path("/UsuariosService")
public class UsuariosService
{
    @GET
    @Path("/usuarios")
    @Produces("application/json")
    public String usuarios()
    {
        String usuarios = null;
        ArrayList<Usuarios> usuariosList = new ArrayList<Usuarios>();
        try
        {
            usuariosList = new AccessManager().getUsuarios();
            Gson gson = new Gson();
            //usuarios = gson.toJson(usuariosList);
            usuarios = "{\"usuarios\" :" + gson.toJson(usuariosList) + "}";
        } catch (Exception e)
        {
                e.printStackTrace();
        }
        return usuarios;
    }
}

1 个答案:

答案 0 :(得分:2)

通常你应该问一个特定的麻烦,而不是要求样品。看起来你有一个结构化的代码,你所需要的只是实现作为服务公开的所有操作。

如果您需要样本,网上有相当多的资源。这样的事情:https://code.google.com/p/javaee6-crud-example/

我会尝试给你一些快速提示:

WebService - UsuariosService.java

@POST
@Path("/usuarios")
public Response save(Usuario user) {
    try {
        manager= new AccessManager();
        manager.save(user);
        return Response.ok("User has been created.").build();
    } catch (Exception e) {
            e.printStackTrace();
    }
    return usuarios;
}

@DELETE
@Path("/usuarios/{id}")
public Response delete(@PathParam("id") String id) {
    try {
        manager= new AccessManager();
        manager.delete(id);
        return Response.ok("User has been deleted.").build();
    } catch (Exception e) {
            e.printStackTrace();
    }
    return usuarios;
}

@PUT
@Path("/usuarios/{id}")
public Response delete(@PathParam("id") String id, Usuario user) {
    try {
        manager= new AccessManager();
        manager.update(id, user);
        return Response.ok("User has been updated.").build();
    } catch (Exception e) {
            e.printStackTrace();
    }
    return usuarios;
}

如果你不理解PUT,DELETE,POST等的用法,我建议你阅读HTTP Method Tutorial。关于这一点有几个讨论,但你可能会暂时搁置它。

我想你可以从这里得到一个想法。您的DAO也需要实现执行CRUD接口的方法。我添加的链接有一个非常简单的示例,也可能有所帮助。您也可以查看此JPA链接。

不确定上面的信息是否有帮助,但我认为这是一个开始,因为您必须对其进行编码才能了解更多信息:)