gpt4 book ai didi

java - Struts2 - 具有多种方法的 Action ?

转载 作者:搜寻专家 更新时间:2023-11-01 03:10:12 24 4
gpt4 key购买 nike

我是这个网站的新手,这是我的第一个问题。

我必须做一个网站,我正在使用 java 和 Struts2,但我是 Struts2 的新手。

在我的站点中,我必须向 Facebook 发出请求并使用 OAuth 进行身份验证。

我在操作页面的执行方法中执行所有过程(验证和请求 protected 资源),这个过程非常复杂,并且在 Facebook 和我的网站之间有很多重定向。

前几天我读到“不要使用多种方法创建操作:“执行”和您要执行的操作(例如“createUser”)应该足够了”(来自 http://freeopenidea.blogspot.com.es/2010/04/struts2-best-practices.html)。

大多数代码可以在另一时刻从我网站的另一部分调用,因为我在第一次连接时执行此过程,但我可以执行此操作(或类似操作)来刷新联系人列表。

1 - 我应该为我需要的方法创建一个单独的类(不是 Action )并从“执行”方法调用它们吗?

2 - 我应该将代码保留在操作页面中,但保留在“执行”之外的方法中吗?每次我需要执行某些任务时调用此页面。

我不知道把代码放在哪里(我知道,我必须存储 de accessToken。我只是粘贴代码以显示复杂性但不看更正)。

public String execute() throws Exception{
if (code!=null){
Verifier verifier = new Verifier(code);
//get the accessToken to do requests
Token accessToken = service.getAccessToken(EMPTY_TOKEN, verifier);
OAuthRequest requestList = new OAuthRequest(Verb.GET, PROTECTED_RESOURCE_URL);
service.signRequest(accessToken, requestList);
Response responseList = requestList.send();
if (responseList.getCode() == 200){
//I get the Friends List
JsonParse parser = new JsonParse();
JSONObject json = (JSONObject) JSONSerializer.toJSON(responseList.getBody());
JSONArray datos = json.getJSONArray("data");
for (Object o : datos)
{//for every friend of the list I do this
JSONObject elem = (JSONObject) o;
String id = elem.getString("id");
OAuthRequest requestFriend = new OAuthRequest(Verb.GET,"https://graph.facebook.com/"+id);
service.signRequest(accessToken, requestFriend);
Response responseFriend = requestFriend.send();
if (responseFriend.getCode() == 200){
JsonParse parserAux = new JsonParse();
PerfilContacto pcBean = parserAux.parseFacebookElement(responseFriend.getBody());
pcDAO.insertarContacto(pcBean);
}
}
}
return SUCCESS;
}
else return ERROR;
}

最佳答案

在我看来,操作方法中的代码太多了。 Actions 应该处理 web 和业务层之间的层,除此之外别无其他。这种耦合程度,尤其是硬编码的类实例化,使得单独测试操作的逻辑变得非常困难。

基本上将所有代码移到服务中。该操作仅与服务交互有关。该框架验证 code 的存在。该服务在 Struts 2 之外进行测试。该操作使用模拟服务进行测试。

完全未经测试,但我怀疑我的代码看起来更接近于下面的内容。它用一种类型的复杂性换取另一种类型的复杂性,但带来了多重好处。每种方法都重点突出且易于阅读。服务调用是隔离的,这使我们能够测试不同模式的服务失败。它是系统行为和功能的精细表示。

Action

public String execute() throws Exception {
fbService.updateFriends(code);
return SUCCESS;
}

Facebook 服务

public void updateFriends(String code) {
Token accessToken = getAccessToken(code);
Response response = getFriends(accessToken);
if (response.getCode() == 200) {
processFriends(accessToken, response);
}
}

private void processFriends(Token accessToken, Response response) {
JSONObject json = (JSONObject) JSONSerializer.toJSON(response.getBody());
JSONArray datos = json.getJSONArray("data");
for (Object o : datos) {
JSONObject friend = (JSONObject) o;
processFriend(friend);
}
}

private void processFriend(Token accessToken, JSONObject friend) {
Response response = getFriendGraph(accessToken, friend.getString("id"));
if (response.getCode() == 200){
PerfilContacto pcBean = new JsonParse().parseFacebookElement(response.getBody());
pcDAO.insertarContacto(pcBean);
}
}

//~ Service interaction

private Response getFriends(Token accessToken) {
return sendSignedGetRequest(PROTECTED_RESOURCE_URL, accessToken);
}

private Response getFriendGraph(Token accessToken, String id) {
return sendSignedGetRequest("https://graph.facebook.com/" + id, accessToken);
}

private Token getAccessToken(String code) {
return service.getAccessToken(EMPTY_TOKEN, new Verifier(code));
}

private Response sendSignedGetRequest(String url, Token accessToken) {
OAuthRequest request = new OAuthRequest(Verb.GET, url);
service.signRequest(accessToken, request);
return request.send();
}

如果我们考虑指标,我们最终会得到以下结果。

原文:

Average Function NCSS:      24.00
Average Function CCN: 6.00
Program NCSS: 25.00

重做:

Average Function NCSS:       3.63
Average Function CCN: 1.38
Program NCSS: 31.00

最终,这意味着:

  • 重要的 LOC 数量没有增加太多。
  • 每个函数的长度 < 4 行(易于阅读)。
  • 每个函数的圈复杂度 < 2(易于测试和推理)。
  • 程序读起来更像它正在做的事情,可以更快地理解。

代价是我们有更多的方法(考虑到任何合理的 IDE 或文本编辑器,这不应该是一个问题),一种复杂性。然而:

  • 我们可以在我们选择的深度停止阅读。
  • 我们可以进行更精细的测试。
  • 我们可以确定我们可能错过的成功/失败模式。
  • 我们可以更轻松地交换和/或扩展功能。

关于java - Struts2 - 具有多种方法的 Action ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12499618/

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