導航:首頁 > IDC知識 > 二級域名session

二級域名session

發布時間:2020-12-11 02:35:17

1、tomcat9怎麼修改源碼實現二級域名共享session

1、jar包
的jar有:
memcached-session-manager-1.5.1.jar, memcached-session-manager-tc6-1.5.1.jar,
manager/downloads/list
2、把的jar包放到%TOMCAT_HOMT%\lib中。
3、配置%TOMCAT_HOME%\config\context.xml
在Context.xml文件中加入

2、.net多個二級域名共用Session的問題

用cookies吧

定義一個cookies的基本方法有

HttpCookie cookies_bh = new HttpCookie("bh"); //定義新cookies
cookies_bh.Value = "新cookies";
cookies_bh.Expires = DateTime.Now.AddDays(10);
Response.AppendCookie(cookies_bh);

那麼就可以讀取了
Request.Cookies["cookies_bh"].Value

3、asp如何在二級域名間共享session

除非你的二級域名抄不是真名的(這兒用詞不太准)
也就是說 你的域名是泛域名 不管輸入什麼二級域名都到同一個IP上
然後在這個IP的默認頁上 判斷訪問來的域名是什麼 然後去掉 域名中的一級部分 把二級域名部分變成一個變數的參數 在帶著這個參數跳到相關頁面
這樣所有的二級域名進的都 是同一個網站 也就是共享session

如:http://123.ejsj.com
進來後跳到 http://www.ejsj.com/id=123

4、asp.net 一級域名與二級域名取 session

 Asp.Net中的Session要比Asp中的Session靈活和強大很多,同時也復雜很多;看到有一些Asp.Net開發人員報怨說不穩定,莫名其妙的丟失,其實這正是Asp.Net改進的地方之一。
我們知道Session與Cookie最大的區別在於:Cookie信息全部存放於客戶端,Session則只是將一個ID存放在客戶端做為與服務端驗證的標記,而真正的數據都是放在服務端的內存之中的。
在傳統web編程語言(比如asp)中,session的過期完全是按照TimeOut來老老實實處理的,超時值默認是20分鍾,但問題是:通常有很多用戶只看一眼網頁,然後就關瀏覽器走人了,這種情況下,服務端內存里還長久保存著Session的數據,如果這種用戶很多,對伺服器資源無疑是一種浪費。
而在Asp.Net中,Session的存儲策略有好幾種:

默認情況下,系統採用的是InProc模式,即進程內模式。這種情況下,Session是保存在Asp.Net工作進程映射的內存中的,問題是Asp.Net工作進程為了維護良好的平均性能,會被系統經常回收。我們在IIS里可以配置自動回收(比如按時間周期回收,或者當內存使用達到多少值時自動回收),如下圖即為IIS7中配置應用程序池回收參數的界面:
當Asp.Net工作進程被回收時,其映射的內存全部被清空並初始化,以便其它程序可以使用,所以Session也跟著一並消失了,就這是為什麼Sesssion會無故消失的主要原因。
當然默認的InProc模式也是性能最高的一種模式,如果您不能忍受這種「不穩定」,可以在web.config中把mode設置為StateServer模式:
<sessionState mode="StateServer" stateConnectionString="tcpip=127.0.0.1:42424"></sessionState>

這種情況下Session會被保存在Asp.Net進程之外的aspnet_state.exe進程中,這個進程不受asp.net進程回收的影響。但要注意:aspnet_state是以windows服務形式運行的,所以請先確保127.0.0.1對應的機器上該服務已經啟動。

另外,我們也必須意識到:雖然StateServer模式下session會穩定很多,但是性能相對InProc而言是有損耗的(大概在15%~25%左右),因為系統內部要將session值序列化以後,保存到aspnet_state進程映射的內存中,讀取的時候還要反序列化。
這種模式還有一個優點:如果tcpip=127.0.0.1:42424中的IP地址指定為另外一台伺服器,意味著可以將session保存在web伺服器以外的機器上。
session信息甚至還能保存到SqlServer資料庫中:
進入vs命令行模式,輸入以下命令:

即aspnet_regsql -S 資料庫實例名 -ssadd -U 連接用戶名。注意:資料庫伺服器得先啟動Sql Server代理服務:

該命令運行後,將會自動創建一個AspState資料庫,同時會在tempdb資料庫下創建二張表ASPStateTempApplications與ASPStateTempSessions。
對應的web.config配置為:
<sessionState mode="SQLServer" sqlConnectionString="data source=JIMMYT61P;uid=sa;pwd=***"></sessionState>

註:如果想把表直接創建在資料庫ASPState中,剛才的命令行中,再加一個參數 -sstype p ,即:
aspnet_regsql -S 資料庫實例名 -ssadd -sstype p -U 連接用戶名
同樣SqlServer模式在保存讀取Session數據時,相對InProc模式也會有性能損耗(大約在25%左右),但利用SqlServer能實現Session數據的持久保存。
最後再來看看mode中的另外二個值: Off與Custom,Off 相當於禁用了session,就不多說了,Custom 允許開發人員自己定義Session如何存儲,相當於提供了一個可供編程的開發介面(我從來沒用過,所以...也談不出很深的道道來,呵呵)。
綜合一下:InProc性能最高,但是有可能會使session無故丟失,而且這種模式無法適用於web伺服器集群或負載均衡場景(因為多台伺服器之間無法實現Session同步),StateServer與SqlServer可應用於web伺服器集群場景,但是性能有所降低;如果希望Session能持久化保存,SqlServer是唯一的內置方案。
個人經驗:一般情況下,我傾向於使用cookie,從而減少對伺服器資源的消耗,但是這也要找一個平衡點,因為服務端代碼中要得到客戶端的cookie,也就意味著cookie文件必須通過瀏覽器傳遞到伺服器,同樣會消耗網路帶寬。另外在一些博客系統中,比如用戶寫文章時,如果中途離開了下,然後繼續寫,等到保存時會發現session已經失效,頁面跳到登錄頁,辛苦打了N多字卻沒了!這時可考慮用代碼一直維系session,即麒麟兄弟的心跳思想:讓你的網站"心跳"起來 ,或者用ajax每隔幾分鍾自動保存一次。再者從安全性上講,偽造session要比cookie難得多,相對更安全一些。

5、為什麼在二級域名中取不到session?

session是針對域名的 不是針對目錄的 要不同域名下session通用要做共享處理 可以用資料庫存儲或者其他方法~

6、同一個項目,能從主站(一級域名)向二級域名傳session嗎

不可以的。不過,可以通過變通的方法解決。具體過程如下:
1.你可以使用在訪問二級域名的時候,添加url參數。
2.在訪問二級域名所在的頁面時,把參數保存到二級域名所屬的程序的session中。

7、PHP網頁如何設置二級域名共享session

站點和站點之間是不能共享SESSION的,不管是幾級域名。但是可以通過寫cookie的方法或者單點登錄、WEBSERVICE等技術使站點之間的信息相互交換和共享。

8、asp.net 一級域名與二級域名 session,取值問題。

session必須在同一個域中才能共享。而「www.我的域名.com」與「changsha.我的域名.com」會被認為是不同回域,因為盡管它答們的純域名相同,但是它們是可以指向兩個毫無關聯的IP地址的,所以在網路上它們會被認為是「不同域」。
不但如此,你就是用純域名,比如 http://我的域名.com/b.aspx 同樣是取不到session["a"]的!只有域名完全相同的才會被認為「同域」!

9、兩台一級域名相同二級域名不同的伺服器,怎麼共享session

不可以的。不過,可以通過變通的方法解決。具體過程如下: 1.你可以使用在訪問二級域名的時候,添加url參數。 2.在訪問二級域名所在的頁面時,把參數保存到二級域名所屬的程序的session中。

與二級域名session相關的知識