会话session
維系一個會話,最常見的有兩種方式:?
一是基于某種憑證,比如web網站的登錄會話,在登錄驗證之后,服務器就會返回一個session id作為憑證。用戶之后的請求總是會帶上這個id,而服務器通過這個id也就能知道用戶是誰。直到用戶注銷登錄、或者登錄超時,服務器會清洗掉對應的session id,這個id就失效了,會話也就隨之而結束。?
第二種方式是基于連接的,當用戶和系統之間的連接啟用時,系統會對用戶進行驗證,驗證通過之后,來自這個連接的操作都是屬于這個用戶的。直到連接斷開,則會話結束。?
?
linux系統的會話就是以第二種方式來維系的。會話基于連接,那么連接的安全性就決定了會話的安全性。以最常見的兩種連接為例:?
1、本地連接,用戶是直接通過鍵盤顯示器來跟系統交互的,鍵盤顯示器直接連接在主機上,連接被篡改基本上是不可能的;?
2、遠程連接,以ssh為例,其協議會進行加密,從而避免連接被篡改;?
?
?
?
?
調用以下函數可以使進程成為會話組長:
要注意的是:?
1.調用進程不能是進程組組長,該進程變成新會話首進程(session header)?
2.該進程成為一個新進程組的組長進程。?
3.需有root權限(ubuntu不需要)?
4.新會話丟棄原有的控制終端,該會話沒有控制終端?
5.該調用進程是組長進程,則出錯返回?
6.建立新會話時,先調用fork, 父進程終止,子進程調用
?
#include <stdio.h> #include <stdlib.h> #include <unistd.h>int main(void) {pid_t pid;if ((pid = fork())<0) {perror("fork");exit(1);} else if (pid == 0) {printf("child process PID is %d\n", getpid());printf("Group ID of child is %d\n", getpgid(0));printf("Session ID of child is %d\n", getsid(0));sleep(10);setsid(); // 子進程非組長進程,故其成為新會話首進程,且成為組長進程。該進程組id即為會話進程printf("Changed:\n");printf("child process PID is %d\n", getpid());printf("Group ID of child is %d\n", getpgid(0));printf("Session ID of child is %d\n", getsid(0));sleep(20);exit(0);}return 0; }輸出結果: child process PID is 3978 Group ID of child is 3977 Session ID of child is 3305 Changed: child process PID is 3978 Group ID of child is 3978 Session ID of child is 3978?
通過以下函數查看會話進程ID
pid_t getsid(pid_t pid)pid為0表示察看當前進程session ID
注:組長進程不能成為新會話首進程,新會話首進程必定會成為組長進程。
?
轉載于:https://www.cnblogs.com/13224ACMer/p/6413858.html
總結
- 上一篇: android studio连接真机问题
- 下一篇: destoon 屏蔽会员组,让个人,游客