2016-09-29 2 views
0

githubのdropwizardの例に似たput restメソッドを使っている例をオンラインで見てみましたが、実際には見つかりませんでした。dropwizardを使ってputオペレーションを実装するにはどうすればいいですか

はここにここに私のPersonDAO.javaコード

public class PersonDAO extends AbstractDAO<Person> { 
    public PersonDAO(SessionFactory factory) { 
     super(factory); 
    } 
    public Optional<Person> findById(Long id) { 
     return Optional.fromNullable(get(id)); 
    } 

    public Person create(Person person) { 
     return persist(person); 
    } 

    public List<Person> findAll() { 
     return list(namedQuery("com.example.helloworld.core.Person.findAll")); 
    } 
    //here i want to create delete method 
} 

は私のREST APIコードです:ここ

@Path("/people") 
@Produces(MediaType.APPLICATION_JSON) 
public class PeopleResource { 

    private final PersonDAO peopleDAO; 

    public PeopleResource(PersonDAO peopleDAO) { 
     this.peopleDAO = peopleDAO; 
    } 

    @POST 
    @UnitOfWork 
    public Person createPerson(Person person) { 
     return peopleDAO.create(person); 
    } 

    @GET 
    @UnitOfWork 
    public List<Person> listPeople() { 
     return peopleDAO.findAll(); 
    } 

    @GET 
    @Path("/{id}") 
    public Optional<Person> getUser(@PathParam("id") Integer id) { 
     Optional<Person> person = peopleDAO.findPeopleById(id); 
     return person; 
    } 
    //here should be put method that calls dao class 
} 

は私のperson.javaクラスは

@Entity 
@Table(name = "people") 
@NamedQueries(
    { 
     @NamedQuery(
      name = "com.example.helloworld.core.Person.findAll", 
      query = "SELECT p FROM Person p" 
     ) 
    } 
) 
public class Person { 
    @Id 
    @GeneratedValue(strategy = GenerationType.IDENTITY) 
    private long id; 

    @Column(name = "fullName", nullable = false) 
    private String fullName; 

    @Column(name = "jobTitle", nullable = false) 
    private String jobTitle; 

    public Person() { 
    } 

    public Person(String fullName, String jobTitle) { 
     this.fullName = fullName; 
     this.jobTitle = jobTitle; 
    } 

    public long getId() { 
     return id; 
    } 

    public void setId(long id) { 
     this.id = id; 
    } 

    public String getFullName() { 
     return fullName; 
    } 

    public void setFullName(String fullName) { 
     this.fullName = fullName; 
    } 

    public String getJobTitle() { 
     return jobTitle; 
    } 

    public void setJobTitle(String jobTitle) { 
     this.jobTitle = jobTitle; 
    } 

    @Override 
    public boolean equals(Object o) { 
     if (this == o) { 
      return true; 
     } 
     if (!(o instanceof Person)) { 
      return false; 
     } 

     final Person that = (Person) o; 

     return Objects.equals(this.id, that.id) && 
       Objects.equals(this.fullName, that.fullName) && 
       Objects.equals(this.jobTitle, that.jobTitle); 
    } 

    @Override 
    public int hashCode() { 
     return Objects.hash(id, fullName, jobTitle); 
    } 
} 

ある任意の使いやすいがあります方法を提案する/ putメソッドを実装する?

+0

入札依頼を意味しますか?リソースメソッドの上に@ Get、@ Post、@ Put、@ Deleteアノテーションを使用して、サポートする操作を指定することができます。試してみるとエラーが出ますか? – Brion

答えて

0

リソース:

@PUT 
public Person update(Person person) { 
    return peopleDAO.update(person); 
} 

DAO:

public Person update(Person person) { 
    return persist(person); 
} 

は、あなたのIDがnullでないことを確認してください。ロジックを作成または更新します。

+0

これはデータベース内のエントリを置き換えますか?たとえば、puthostと私のURLをlocalhost http:// localhost:8080/people/2に入れて、2つがデータベースのプライマリIDの場合、データベースの2番目のエントリが更新されますか? – Bob

+0

はい。あなたがコントロールを持っていなければ。このような状態では、@ Versionアノテーション付きの列を使用しています。 たとえば、 – Hasan

+0

@Version プライベートlong lastUpdated; – Hasan

関連する問題