1. java後台action接受到兩個參數,怎麼傳到層
假設你的 DAO層的CLASS 名字是 GetValueDao,裡面自己定義了一些變數名,必須要有get、set方法。那麼在action中 先 GetValueDao gvd = new GetValueDao()
gvd.setValue1(你接收的參數1);
gvd.setValue2(你接收的參數2);
2. java中對象.action(true)什麼意思
//調用Move對象的actioon()方法,true是參數
m.action(true);
//定義一個布爾類型的變數flag,
boolean
flag
=
false;
//
if語句如果flag是false就不會執行這個代碼段,反之則執行。if是一個判斷用的
if(flag){
......//代碼段
}
3. java中的action是什麼,DAO又是什麼
Action類 是[獲得Form表單數據,並處理邏輯的類]
DAO(Data Access Object) 是一個介面實現[通過SessionFactory獲得操作資料庫的會話,並實現一些基本的刪除 添加 修改數據,在servlet中更實際化業務操作]
4. java中請求參數action怎麼獲取
1. ActionContext
在Struts2開發中,除了將請求參數自動設置到Action的欄位中,我們往往也需要在Action里直接獲取請求(Request)或會話(Session)的一些信息,甚至需要直接對JavaServlet Http的請求(HttpServletRequest),響應(HttpServletResponse)操作. 我們需要在Action中取得request請求參數"username"的值:
ActionContext context = ActionContext.getContext();
Map params = context.getParameters();
String username = (String) params.get("username");
on執行時的上下文,上下文可以看作是一個容器(其實我們這里的容器就是一個Map而已),它存放的是Action在執行時需要用到的對象. 一般情況, 我們的ActionContext都是通過: ActionContext context = (ActionContext) actionContext.get();來獲取的.我們再來看看這里的actionContext對象的創建:
static ThreadLocal actionContext = new ActionContextThreadLocal();
ActionContextThreadLocal是實現ThreadLocal的一個內部類.ThreadLocal可以命名為"線程局部變數",它為每一個使用該變數的線程都提供一個變數值的副本,使每一個線程都可以獨立地改變自己的副本,而不會和其它線程的副本沖突.這樣,我們ActionContext里的屬性只會在對應的當前請求線程中可見,從而保證它是線程安全的.
通過ActionContext取得HttpSession: Map session = ActionContext.getContext().getSession();
2. ServletActionContext
ServletActionContext(com.opensymphony.webwork. ServletActionContext),這個類直接繼承了我們上面介紹的ActionContext,它提供了直接與Servlet相關對象訪問的功能,它可以取得的對象有:
(1)javax.servlet.http.HttpServletRequest : HTTPservlet請求對象
(2)javax.servlet.http.HttpServletResponse : HTTPservlet相應對象
(3)javax.servlet.ServletContext : Servlet上下文信息
(4)javax.servlet.ServletConfig : Servlet配置對象
(5)javax.servlet.jsp.PageContext : Http頁面上下文
如何從ServletActionContext里取得Servlet的相關對象:
<1>取得HttpServletRequest對象: HttpServletRequest request = ServletActionContext. getRequest();
<2>取得HttpSession對象: HttpSession session = ServletActionContext. getRequest().getSession();
3. ServletActionContext和ActionContext聯系
ServletActionContext和ActionContext有著一些重復的功能,在我們的Action中,該如何去抉擇呢?我們遵循的原則是:如果ActionContext能夠實現我們的功能,那最好就不要使用ServletActionContext,讓我們的Action盡量不要直接去訪問Servlet的相關對象.
注意:在使用ActionContext時有一點要注意: 不要在Action的構造函數里使用ActionContext.getContext(),因為這個時候ActionContext里的一些值也許沒有設置,這時通過ActionContext取得的值也許是null;同樣,HttpServletRequest req = ServletActionContext.getRequest()也不要放在構造函數中,也不要直接將req作為類變數給其賦值。至於原因,我想是因為前面講到的static ThreadLocal actionContext = new ActionContextThreadLocal(),從這里我們可以看出ActionContext是線程安全的,而ServletActionContext繼承自ActionContext,所以ServletActionContext也線程安全,線程安全要求每個線程都獨立進行,所以req的創建也要求獨立進行,所以ServletActionContext.getRequest()這句話不要放在構造函數中,也不要直接放在類中,而應該放在每個具體的方法體中(eg:login()、queryAll()、insert()等),這樣才能保證每次產生對象時獨立的建立了一個req。
4. struts2中獲得request、response和session
(1)非IoC方式
方法一:使用org.apache.struts2.ActionContext類,通過它的靜態方法getContext()獲取當前Action的上下文對象。
ActionContext ctx = ActionContext.getContext();
ctx.put("liuwei", "andy"); //request.setAttribute("liuwei", "andy");
Map session = ctx.getSession(); //session
HttpServletRequest request = ctx.get(org.apache.struts2.StrutsStatics.HTTP_REQUEST);
HttpServletResponse response = ctx.get(org.apache.struts2.StrutsStatics.HTTP_RESPONSE);
細心的朋友可以發現這里的session是個Map對象, 在Struts2中底層的session都被封裝成了Map類型. 我們可以直接操作這個Map對象進行對session的寫入和讀取操作, 而不用去直接操作HttpSession對象.
方法二:使用org.apache.struts2.ServletActionContext類
public class UserAction extends ActionSupport {
//其他代碼片段
private HttpServletRequest req;
// private HttpServletRequest req = ServletActionContext.getRequest(); 這條語句放在這個位置是錯誤的,同樣把這條語句放在構造方法中也是錯誤的。
public String login() {
req = ServletActionContext.getRequest(); //req的獲得必須在具體的方法中實現
user = new User();
user.setUid(uid);
user.setPassword(password);
if (userDAO.isLogin(user)) {
req.getSession().setAttribute("user", user);
return SUCCESS;
}
return LOGIN;
}
public String queryAll() {
req = ServletActionContext.getRequest(); //req的獲得必須在具體的方法中實現
uList = userDAO.queryAll();
req.getSession().setAttribute("uList", uList);
return SUCCESS;
}
//其他代碼片段
}
(2)IoC方式(即使用Struts2 Aware攔截器)
要使用IoC方式,我們首先要告訴IoC容器(Container)想取得某個對象的意願,通過實現相應的介面做到這點。
public class UserAction extends ActionSupport implements SessionAware, ServletRequestAware, ServletResponseAware {
private HttpServletRequest request;
private HttpServletResponse response;
public void setServletRequest(HttpServletRequest request) {
this.request = request;
}
public void setServletResponse(HttpServletResponse response) {
this.response = response;
}
public String execute() {
HttpSession session = request.getSession();
return SUCCESS;
}
}
5. Java Action配置
你自己看報錯信息啊..未定義的actionName參數
既然你的result是重定向到另一個action.那麼你就得在result標記之間加上一下參數
<result type="redirectAction">
<param name="namespace">/XXXaction路徑</param>
<param name="actionName">action名稱</param>
</result>
如果是轉發到某個jsp.那麼就沒有必要type="redirectAction",默認是dispatcher
6. java中的action怎麼寫
public interface Actionextends ActionListener
Action 介面提供 ActionListener 介面的一個有用擴展,以便若干控制項訪問相同的功能。
除了 ActionListener 介面定義的 actionPerformed
方法之外,此介面還允許應用程序在一個位置定義:
描述函數的一個或多個文本字元串。這些字元串可用於顯示按鈕的立體文本、在菜單項中設置文本等等。
描述函數的一個或多個圖標。這些圖標可用於菜單控制項中的圖像,或者用於更復雜用戶界面中的合成項。
功能的啟用/禁用狀態。應用程序可以禁用實現此介面的函數,而不必分別禁用菜單項和工具欄按鈕。所有為偵聽狀態更改而注冊為偵聽器的組件都將禁止為該項生成事件,並相應地修改顯示。
可以將此介面添加到現有類中,或者用它創建一個適配器(通常通過子類化 AbstractAction 來實現)。然後可以將
Action 對象添加到多個可感知 Action 的容器中,並連接到可容納
Action 的組件。然後可以通過調用 Action 對象的 setEnabled
方法立刻激活或取消激活 GUI 控制項。
注意,Action 實現在存儲方面的開銷比典型的 ActionListener
要高,但後者不具有集中控制功能和廣播屬性更改的優點。因此,應該注意只在需要這些優點的地方使用 Action,在別處使用
ActionListener 即可。
支持 Action 的 Swing 組件
許多 Swing 的組件都具有 Action 屬性。在組件上設置 Action
時,會發生以下幾種情況:
Action 被作為 ActionListener 添加到組件。
組件配置自身的某些屬性以匹配 Action。
組件在 Action 上安裝 PropertyChangeListener,這樣組件可更改其屬性以反映 Action 屬性中的更改。
7. java系統方法action()的用法
用map存數據key存編號values存個你新建的類新建的類里存書的屬性map。put(1111,book)
8. java系統方法action()是什麼
你可以用this.方法名的方式調用本類中的方法,其它類中的方法需要你創建對應的action對象來調用