在 java 開(kāi)發(fā)中,避免不了要對(duì)共享文件進(jìn)行操作,前段時(shí)間小編就做了類(lèi)似的需求,這里記錄開(kāi)發(fā)中遇到的坑,一是記錄,而是希望有同樣需求的小伙伴燒踩一些坑。
在連接共享文件時(shí) ,我們避免不了要輸入用戶(hù)名&密碼,但是smb協(xié)議可以有兩種寫(xiě)法
方法一:
/*
* ? Smb://(用戶(hù)名):(密碼)@(ip)/(共享文件名稱(chēng))
*/
String path="Smb://dzjz:123@172.16.192.106/unupload/";
SmbFile smbFile=newSmbFile(path);
然后就可以進(jìn)行后續(xù)的驗(yàn)證了。
但是:::: 這種寫(xiě)法會(huì)有個(gè)坑,其中的@符是連接作用,假如你的密碼中有特殊字符(例如:@!#。。等),這樣的話(huà)你的共享文件一直是鏈接不上的,那么有沒(méi)有解決辦法呢 ?肯定是有的下面我們來(lái)時(shí)第二種方法
方法二:
/*
* 還是上面的 用戶(hù)名密碼
*/
String domainip="172.16.192.106";
String userName="dzjz";
String passWord="123";
String fileName="unupload";
String url="smb://172.16.192.106/unupload/" ;
NtlmPasswordAuthentication auth =new NtlmPasswordAuthentication(domainip, username, password);
SmbFile outDirFile =newSmbFile(url, auth);
//或者 SmbFile outDirFile =newSmbFile("smb://"+domainip+"/"+fileName+"/", auth);
這樣就可以完美解決了用戶(hù)名或者密碼中存在攤位數(shù)字符的問(wèn)題。
這種寫(xiě)法簡(jiǎn)單的來(lái)說(shuō)就是優(yōu)先驗(yàn)證用戶(hù)信息 ,然后給你個(gè)封裝好的鑰匙,再去打開(kāi)你想要訪問(wèn)的共享文件,具體原理就不在這里說(shuō)了 有興趣的大家可以看下源碼。
還有一點(diǎn),也是比較坑的一點(diǎn):就是smb協(xié)議訪問(wèn)的共享文件是加了同步鎖的,當(dāng)有一個(gè)smb協(xié)議扎起使用連接著當(dāng)前的共享文件時(shí),其他的協(xié)議是無(wú)法連接通過(guò)的。(關(guān)于這一點(diǎn)大家可以看下源碼的具體實(shí)現(xiàn)。)