使用struts2製做後臺中的問題記錄

先貼上數據庫表的結構javascript

一、session問題java

一開始的代碼是這樣的。web

login的action:sql

if(adminService.login(admin)){
ActionContext.getContext().getSession().put("admin",admin);
return SUCCESS;
}數據庫

index.jsp:express

<li><%=session.getAttribute("admin")%></li>windows

在頁面上顯示的是bean.Admin@1e61605,百度了一下,這應該是存儲地址。瀏覽器

可是index.jsp裏寫<s:property value="%{#session.admin}"/>或<s:property value="#session.admin"/>,顯示的是空白。session

我考慮到多是由於admin裏面包含adm_name和adm_pw,因此把上述代碼改爲了<s:property value="#session.admin.adm_name"/>,仍是顯示空白框架

因此我改了action的代碼

if(adminService.login(admin)){
ActionContext.getContext().getSession().put("adm_name",admin.getAdm_name);
   return SUCCESS;
}

這樣在index.jsp中寫上<li><%=session.getAttribute("adm_name")%></li>就能夠正常顯示了。

二、改進

若是想要在頁面中顯示漢字,那麼登錄時候用戶名也要打漢字,這樣很不方便。用戶名和暱稱應該分開。因此,我在bean中重構了adm_realname,action改成

if(adminService.login(admin)){
ActionContext.getContext().getSession().put("adm_realname",admin.getAdm_realname);
  return SUCCESS;
}

運行後,頁面顯示爲null。爲何admin.getAdm_realname取不到值呢?我就把business中的sql語句改爲

ResultSet rs= stmt.executeQuery("select * from admin where adm_realname='"+admin.getAdm_realname()+"'");

這一改可好,登錄不進去了。我很納悶啊,就在bean和business中設置了斷點進行調試,發現bean中封裝的字段,adm_id和adm_realname爲null,我填寫的adm_realname卻賦值給了adm_name,我才恍然大悟,login.jsp中用的s標籤,<s:textfield name="admin.adm_name" placeholder="用戶名" required="required"/>。

我把sql語句有改回去,想了想,adm_id取值也是null,說明bean只會封裝提交的adm_name和adm_pw,並不會主動獲取全部的值。(好吧,不要說我傻,畢竟我是個只會用servlet的寶寶/(ㄒoㄒ)/~~)

而後我就在business裏面加了這樣的語句

ResultSet rs= stmt.executeQuery("select adm_realname from admin where adm_name='"+admin.getAdm_name()+"'and adm_pw ='"+admin.getAdm_pw()+"'");

if(rs.next()){
String adm_realname=rs.getString("adm_realname");
admin.setAdm_realname(adm_realname);
return true;
}

即若是登錄成功,把select到的adm_realname  set住,而後再action中就能夠get到了。完美解決問題~啦啦啦~

三、首頁的退出功能

退出功能很簡單,只要把退出用超連接鏈到登錄頁面就好啦,我平時就是這麼作的。(正經網站應該不是這麼退出的,我只是本身寫成這樣的。)可是!由於首頁用了frame框架,退出的按鈕在head區域,我一點擊退出,成了最上面的區域顯示登錄頁面,下面仍是後臺的頁面。以下圖

上網查了一下,應該寫成<a href="javascript:parent.window.location.href= 'login.jsp';">退出</a>才能獲得我想要的效果。下面是查到的信息

文章一:關於js"window.location.href""location.href""parent.location.href""top.location.href"的用法

"window.location.href"、"location.href"是本頁面跳轉

"parent.location.href"是上一層頁面跳轉 
"top.location.href"是最外層的頁面跳轉 
舉例說明:

若是A,B,C,D都是jsp,D是C的iframe,C是B的iframe,B是A的iframe,若是D中js這樣寫 
"window.location.href"、"location.href":D頁面跳轉

"parent.location.href":C頁面跳轉

"top.location.href":A頁面跳轉

若是D頁面中有form的話,

<form>:  form提交後D頁面跳轉

<form target="_blank">:form提交後彈出新頁面
<form target="_parent">:form提交後C頁面跳轉
<form target="_top"> :  form提交後A頁面跳轉
關於頁面刷新,D 頁面中這樣寫:
"parent.location.reload();": C頁面刷新 (固然,也可使用子窗口的 opener 對象來得到父窗口的對象:window.opener.document.location.reload(); )
"top.location.reload();": A頁面刷新

-------------------------------------------------------------------------------

文章二:a href=# a href=javascript:void(0) 的區別,以及location.href含義

1.location:

是windows窗口內的一個對像,它主要功能是從當前的網頁導向另外
一個網頁,href是它的一個屬性.經過它能夠導向另一個網頁同時也刷新了此網頁.

2.

<a href="#"> 點擊連接後,頁面會向上滾到頁首,# 默認錨點爲 #TOP

<a href="JavaScript:void(0)" onClick="window.open()"> 點擊連接後,頁面不動,只打開連接

<a href="#" onclick="javascript:return false;"> 做用同上,不一樣瀏覽器會有差別。

點擊連接後,不想使頁面滾到頁首,就用href="javascript:void(0)",不要用href="#",return false也有相似做用

"#"包含了一個位置信息

默認的錨點是#top 也就是網頁的上端

而javascript:void(0) 僅僅表示一個死連接

這就是爲何有的時候頁面很長瀏覽連接明明是#但是跳動到了頁首

而javascript:void(0) 則不是如此

因此調用腳本的時候最好用void(0)

或者<input onclick>

<div onclick>等

打開新窗口連接的幾種辦法

1.window.open('url')

2.用自定義函數

<script>
function openWin(tag,obj)

{
obj.target="_blank";
obj.href = "Web/Substation/Substation.aspx?stationno="+tag;
obj.click();
}
</script>

<a href="javascript:void(0)" onclick="openWin(3,this)">LINK_TEST</a>

window.location.href=""

-------------------------------------------------------------------------------

若是是個# ,就會出現跳到頂部的狀況,我的收藏的幾種解決方法:
1:<a href="####"></a>
2:<a href="javascript:void(0)"></a>
3:<a href="javascript:void(null)"></a>
4:<a href="#" onclick="return false"></a>
5:<span style="cursor:hand"></span>(好像在FF中不能顯示)

-------------------------------------------------------------------------------

慎用JavaScript:void(0)

今天調試CGI的時候,明明CGI程序已經執行,而且最後結果也是正確的,可是頁面就是不刷新。在FireFox2.0下測試,結果倒是正常的,IE6卻恰恰不刷新!仔細調查了一下,發現cgi頁面連接的是 <a href="javaScript:void(0)" OnClick="XXX_Func();" ….> only a sample </a>,問題就出在這個void(0)上!讓咱們先來看看JavaScript中void(0)的含義:

JavaScript中void是一個操做符,該操做符指定要計算一個表達式可是不返回值。
void 操做符用法格式以下:
1. javascript:void (expression_r_r)
2. javascript:void expression_r_r
expression_r_r是一個要計算的 JavaScript 標準的表達式。表達式外側的圓括號是可選的,可是寫上去是一個好習慣。咱們可使用 void 操做符指定超級連接。表達式會被計算可是不會在當前文檔處裝入任何內容。面的代碼建立了一個超級連接,當用戶點擊之後不會發生任何事。當用戶點擊連接時,void(0) 計算爲 0,但在 JavaScript 上沒有任何效果。

<a href="javascript:void(0)">單擊此處什麼也不會發生</a>

也就是說,要執行某些處理,可是不總體刷新頁面的狀況下,可使用void(0),可是在須要對頁面進行refresh的狀況下,那就要仔細了。

其實咱們能夠這樣用<a href="javascript:void(document.form.submit())">,這句話會進行一次submit操做。那什麼狀況下用void(0)比較多呢,無刷新,固然是Ajax了,看一下Ajax的web頁面的話,通常都會看到有不少的void(0),:) ,因此在使用void(0)以前,最好先想想,這個頁面是否須要總體刷新。

使用javascript的時候,一般咱們會經過相似:
<a href="#" onclick="javascript:方法">提交</a>
的方式,經過一個僞連接來調用javascript方法.這種方法有一個問題是:
雖然點擊該連接的時候不會跳轉頁面.可是滾動條會往上滾,解決的辦法是返回一個false.
以下所示:
<a href="#" onclick="javascript:方法;return false;">提交</a>

還能夠用 ###

a href="javascript:void(0)" onclick="javascript:方法;return false;"提交
javascript:void(0)就不會向上跳了:)

還有一個方法是 #this
a href="#this" onclick="javascript:方法"

 

 Sanding原創,轉載請標註,thank you~

相關文章
相關標籤/搜索