国产亚洲精品福利在线无卡一,国产精久久一区二区三区,亚洲精品无码国模,精品久久久久久无码专区不卡

當(dāng)前位置: 首頁(yè) > news >正文

2015年做啥網(wǎng)站能致富網(wǎng)絡(luò)推廣運(yùn)營(yíng)推廣

2015年做啥網(wǎng)站能致富,網(wǎng)絡(luò)推廣運(yùn)營(yíng)推廣,長(zhǎng)沙有哪些大型工廠,電商網(wǎng)站開發(fā)建設(shè)文章目錄 1. 什么是SFTP2. 什么是Jsch以及它的作用3. Linux中配置SSH密鑰登錄4. sftp服務(wù)器認(rèn)證機(jī)制5. publickey和password兩種方式登錄sftp的API調(diào)用6. 代碼可以如下改造: 需求:做一個(gè)通過(guò)ssh免密登錄的需求,是基于原先密碼登錄sftp服務(wù)器的…

文章目錄

    • 1. 什么是SFTP
    • 2. 什么是Jsch以及它的作用
    • 3. Linux中配置SSH密鑰登錄
    • 4. sftp服務(wù)器認(rèn)證機(jī)制
    • 5. publickey和password兩種方式登錄sftp的API調(diào)用
    • 6. 代碼可以如下改造:

需求:做一個(gè)通過(guò)ssh免密登錄的需求,是基于原先密碼登錄sftp服務(wù)器的代碼上進(jìn)行改造

1. 什么是SFTP

SFTP是一個(gè)安全文件傳送協(xié)議,可以為傳輸文件提供一種安全的加密方法。SFTP 為 SSH的一部份,是一種傳輸文件到服務(wù)器的安全方式。SFTP是使用加密傳輸認(rèn)證信息和傳輸?shù)臄?shù)據(jù),所以,使用SFTP是非常安全的。但是,由于這種傳輸方式使用了加密/解密技術(shù),所以傳輸效率比普通的FTP要低得多,如果您對(duì)網(wǎng)絡(luò)安全性要求更高時(shí),可以使用SFTP代替FTP。

2. 什么是Jsch以及它的作用

Jsch是一個(gè)純粹的用java實(shí)現(xiàn)SSH功能的java library。如果要知道Jsch的功能需先了解一下SSH。SSH是一個(gè)安全協(xié)議,用來(lái)在不同系統(tǒng)或者服務(wù)器之間進(jìn)行安全連接,在連接和傳送數(shù)據(jù)的過(guò)程中會(huì)進(jìn)行加密。SSH一般是基于客戶端的或者Linux命令行,比如window同過(guò)OpenSSH、putty等客戶端的工具,在linux上可以通過(guò)ssh username@host命令進(jìn)行連接。但是如果在Java中如何實(shí)現(xiàn)SSH呢?這時(shí)候便是通過(guò)JSCH來(lái)實(shí)現(xiàn)此的功能。

3. Linux中配置SSH密鑰登錄

SSH 免密登錄可以讓用戶在不輸入密碼的情況下登錄遠(yuǎn)程服務(wù)器,提高登錄效率和安全性

步驟:

  1. 在本機(jī)中生成秘鑰,SSH有專門創(chuàng)建SSH密鑰的工具ssh-keygen 🚩

    - 生成舊版密鑰的命令:ssh-keygen -m PEM -t rsa
    - 生成新版密鑰命令:ssh-keygen -t rsa
    
    • passphrase:生成密鑰時(shí)的密碼
    • 執(zhí)行結(jié)束后,~/.ssh/目錄下會(huì)多兩個(gè)文件:id_rsa(私鑰)、id_rsa.pub(公鑰)
    id_rsa:私鑰
    id_rsa.pub:公鑰
    
  2. 給目標(biāo)服務(wù)器添加公鑰

    ssh-copy-id 用戶名@主機(jī)

    公鑰將被復(fù)制到目標(biāo)服務(wù)器的~/.ssh/authorized_keys文件中。

    ssh-copy-id -p 19222 lihw@10.1.61.118
    

    將公鑰ftp到目標(biāo)服務(wù)器的.ssh后,cd ~/.ssh,手動(dòng)將公鑰導(dǎo)入到authorized_keys信任列表:

    cat 公鑰 >> authorized_keys
    
  3. 更新權(quán)限公鑰權(quán)限

    # 自此SSH免密登錄配置完成。
    chmod 644 authorized_keys
    
  4. 配置服務(wù)器

    在目標(biāo)服務(wù)器上使用文本編輯器打開SSH服務(wù)器的配置文件(通常為/etc/ssh/sshd_config):

    sudo nano /etc/ssh/sshd_config
    

    確保以下配置選項(xiàng)的值為"yes",如果不是,請(qǐng)進(jìn)行相應(yīng)修改:

    RSAAuthentication yes
    PubkeyAuthentication yes
    

    保存修改并關(guān)閉配置文件。
    重新啟動(dòng)SSH服務(wù)器以應(yīng)用更改:

    sudo service ssh restart
    
  5. 測(cè)試使用密鑰登錄

    ssh -p 19222 lihw@10.1.61.118
    

4. sftp服務(wù)器認(rèn)證機(jī)制

Jsch提供了四種認(rèn)證機(jī)制:

  • password 密碼方式
  • publickey(DSA,RSA) 公私鑰方式
  • keyboard-interactive
  • gss-api-with-mic

其中publickey方式通過(guò)配置公私鑰實(shí)現(xiàn)SSH免密登錄,這里也只是簡(jiǎn)單講一下它的使用。

5. publickey和password兩種方式登錄sftp的API調(diào)用

SSH公鑰檢查機(jī)制:

公鑰檢查機(jī)制是一個(gè)安全機(jī)制,可以防范中間人劫持等黑客攻擊。SSH連接遠(yuǎn)程主機(jī)時(shí),會(huì)檢查主機(jī)的公鑰。如果是第一次該主機(jī),會(huì)顯示該主機(jī)的公鑰摘要,提示用戶是否信任該主機(jī)。當(dāng)選擇接受,就會(huì)將該主機(jī)的公鑰追加到文件 ~/.ssh/known_hosts 中。當(dāng)再次連接該主機(jī)時(shí),就不會(huì)再提示該問題了。 但是在某些特殊的情況下,嚴(yán)格的SSH公鑰檢查可能會(huì)破壞一些依賴SSH協(xié)議的自動(dòng)化任務(wù)如Java的Jsch免密登錄sftp程序。解決方式為調(diào)整StrictHostKeyChecking配置指令。StrictHostKeyChecking選項(xiàng)如下3種:

session.setConfig("StrictHostKeyChecking", "no/ask/yes👇");
  • no 最不安全的級(jí)別,當(dāng)然也沒有那么多煩人的提示了,相對(duì)安全的內(nèi)網(wǎng)測(cè)試時(shí)建議使用。如果連接server的key在本地不存在,那么就自動(dòng)添加到文件中(默認(rèn)是known_hosts),并且給出一個(gè)警告。
  • ask 默認(rèn)的級(jí)別,就是出現(xiàn)剛才的提示了。如果連接和key不匹配,給出提示,并拒絕登錄。
  • yes 最安全的級(jí)別,如果連接與key不匹配,就拒絕連接,不會(huì)提示詳細(xì)信息。

下面根據(jù)password來(lái)分析publickey方式與其區(qū)別:

  • 原來(lái)password方式需要這樣一段代碼來(lái)設(shè)置密碼:session.setPassword (properties.getPassword ()); ,但是ssh key的方式就沒有password了,所以這段要?jiǎng)h掉。
  • publickey需要設(shè)置我們的ssh私鑰文件的全路徑(privateKeyFile):jsch.addIdentity (properties.getPrivateKeyFile ());
  • 一般私鑰文件需要口令(passphrase)才能讀取,這需要設(shè)置一個(gè)配置類對(duì)象,在jsch里其實(shí)需要自己搞一個(gè)簡(jiǎn)單的接口實(shí)現(xiàn)(如下:SftpAuthKeyUserInfo類 ),然后增加:session.setUserInfo(new SftpAuthKeyUserInfo (properties.getPassphrase ()));

6. 代碼可以如下改造:

  1. 設(shè)置配置類對(duì)象

    SftpAuthKeyUserInfo.java

import com.jcraft.jsch.UserInfo;
import lombok.extern.slf4j.Slf4j;/*** ssh private key passphrase info*/
@Slf4j
public class UserInfoImpl implements UserInfo {/*** ssh private key passphrase*/private String passphrase;public UserInfoImpl (String passphrase) {this.passphrase = passphrase;}@Overridepublic String getPassphrase() {return passphrase;}@Overridepublic String getPassword() {return null;}@Overridepublic boolean promptPassphrase(String s) {return true;}@Overridepublic boolean promptPassword(String s) {return false;}@Overridepublic boolean promptYesNo(String s) {return true;}@Overridepublic void showMessage(String message) {log.info ("SSH Message:{}", message);}
}
  1. 改造以適配publickey登錄方式
   try {JSch jsch = new JSch();session = jsch.getSession(sftpProperties.getUsername(),sftpProperties.getHost(), sftpProperties.getPort());if (sftpProperties.isCheckToHostKey()) {session.setConfig("PreferredAuthentications", "publickey");session.setConfig("userauth.gssapi-with-mic", "no");session.setConfig("StrictHostKeyChecking", "ask");session.setUserInfo(new SftpAuthKeyUserInfo(sftpProperties.getPassword()));jsch.addIdentity(sftpProperties.getKeyPath());} else {session.setConfig("PreferredAuthentications", "password");session.setConfig("StrictHostKeyChecking", "no");session.setPassword(sftpProperties.getPassword());}session.setConfig("UseDNS", "no");session.setConfig("kex", "diffie-hellman-group1-sha1,"+ "diffie-hellman-group-exchange-sha1,"+ "diffie-hellman-group-exchange-sha256");session.connect(sftpProperties.getConnectTimeout());channelSftp = (ChannelSftp) session.openChannel("sftp");channelSftp.connect();originalDir = channelSftp.pwd();} catch (Exception e) {disconnect();throw new IllegalStateException("failed to create sftp Client", e);}
  1. properties為自定義sftp服務(wù)端配置:
package io.github.lihewei7.easysftp.config;import org.springframework.boot.context.properties.ConfigurationProperties;
import java.util.LinkedHashMap;/*** @explain: SFTP client configuration information* @author: lihewei
*/
@ConfigurationProperties("sftp")
public class SftpProperties {private String host = "localhost";private int port = 22;private String username;private String password = "";/*** Connection timeout.*/private int connectTimeout = 0;/*** Enable jsch log, Cannot be individually turned on or off for one of multiple hosts.*/private boolean enabledLog = false;/*** Whether to use a key to log in*/private Boolean isCheckToHostKey = false;/*** SSH kex algorithms.*/private String kex;/*** host key.*/private String keyPath;/*** Configuring multiple hosts.*/private LinkedHashMap<String,SftpProperties> hosts;public LinkedHashMap<String, SftpProperties> getHosts() {return hosts;}public void setHosts(LinkedHashMap<String, SftpProperties> hosts) {this.hosts = hosts;}public String getHost() {return host;}public void setHost(String host) {this.host = host;}public int getPort() {return port;}public void setPort(int port) {this.port = port;}public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public boolean isEnabledLog() {return enabledLog;}public void setEnabledLog(boolean enabledLog) {this.enabledLog = enabledLog;}public int getConnectTimeout() {return connectTimeout;}public void setConnectTimeout(int connectTimeout) {this.connectTimeout = connectTimeout;}public Boolean isCheckToHostKey() {return isCheckToHostKey;}public void setCheckToHostKey(Boolean checkToHostKey) {isCheckToHostKey = checkToHostKey;}public String getKex() {return kex;}public void setKex(String kex) {this.kex = kex;}public String getKeyPath() {return keyPath;}public void setKeyPath(String keyPath) {this.keyPath = keyPath;}
}
http://aloenet.com.cn/news/39894.html

相關(guān)文章:

  • 哪個(gè)網(wǎng)站有激光打標(biāo)業(yè)務(wù)做線上營(yíng)銷推廣方法
  • 閔行營(yíng)銷型網(wǎng)站建設(shè)公司免費(fèi)網(wǎng)站制作成品
  • 網(wǎng)站開發(fā)人員需要什么要求卡一卡二卡三入口2021
  • 用py做網(wǎng)站b2b網(wǎng)站源碼
  • 網(wǎng)站開發(fā)人員資質(zhì)濟(jì)南網(wǎng)絡(luò)推廣公司
  • 國(guó)外服務(wù)器公司有哪些網(wǎng)站功能優(yōu)化
  • wap仿制網(wǎng)站教程自己搭建一個(gè)網(wǎng)站
  • 建設(shè)京東類的網(wǎng)站需要什么流程域名搜索引擎
  • 監(jiān)控公司建設(shè)網(wǎng)站推廣經(jīng)營(yíng)范圍最全bt磁力搜索引擎索引
  • 小程序 網(wǎng)站建設(shè) app 開發(fā)網(wǎng)絡(luò)營(yíng)銷知名企業(yè)
  • photoshop做圖網(wǎng)站如何利用互聯(lián)網(wǎng)宣傳與推廣
  • 可以做網(wǎng)站的公司軟件推廣接單平臺(tái)
  • 社區(qū)推廣普通話手機(jī)關(guān)鍵詞seo排名優(yōu)化
  • 畢業(yè)設(shè)計(jì)代做網(wǎng)站java湖南網(wǎng)站建設(shè)工作室
  • 設(shè)計(jì)師圖片素材網(wǎng)站適合企業(yè)員工培訓(xùn)的課程
  • 網(wǎng)站建設(shè)的ci設(shè)計(jì)指的是什么視頻運(yùn)營(yíng)管理平臺(tái)
  • 宜興專業(yè)做網(wǎng)站公司搜索競(jìng)價(jià)
  • 網(wǎng)站推廣被封域名如何做跳轉(zhuǎn)網(wǎng)站數(shù)據(jù)統(tǒng)計(jì)工具
  • 領(lǐng)地網(wǎng)做網(wǎng)站咋加文章廣告軟文小故事800字
  • 做律師網(wǎng)站的公司大二網(wǎng)絡(luò)營(yíng)銷實(shí)訓(xùn)報(bào)告
  • 網(wǎng)站建設(shè)課程 谷建軟文推廣服務(wù)
  • 南京疫情最新google seo是什么
  • 潮州專業(yè)網(wǎng)站建設(shè)制作百度競(jìng)價(jià)排名黑幕
  • 網(wǎng)站鏈接查詢seo快速排名軟件首頁(yè)
  • 天津企業(yè)網(wǎng)站設(shè)計(jì)報(bào)價(jià)搜索引擎技術(shù)
  • 做招聘網(wǎng)站賺錢么百度知道推廣軟件
  • 上饒做網(wǎng)站網(wǎng)站備案流程
  • 網(wǎng)站備案號(hào)位置免費(fèi)關(guān)鍵詞優(yōu)化工具
  • 網(wǎng)站開發(fā)實(shí)驗(yàn)報(bào)告可行性分析簡(jiǎn)單網(wǎng)站建設(shè)優(yōu)化推廣
  • asp 做購(gòu)物網(wǎng)站成都全網(wǎng)營(yíng)銷推廣