主要演示文件拖拽上传或点击上传到不同的目录中,提供下载和删除功能。

目录结构:

-main.go

--share(用于分类存放上传文件的目录)

--v(视图目录)

---share.html

main.go

//自编了一个文件共享系统,everyone可上传下载,无权限控制,公网使用风险大,需完善
//所有文件将上传到./share/XXX目录下,可通过http://localhost:8080/share/XXX 访问并下载
//
package main import (
"fmt"
"io"
"io/ioutil"
"os"
"path/filepath"
"sort" "github.com/kataras/iris"
) const (
upload_path string = "./share/"
) //表示一个上传的文件
type Upfile struct {
Url string //位置,如share/XXX/
Name string //文件名,如abc.doc
Date string //文件时间,ModTime转string
} //表示权限
type Allow struct {
UP bool //可上传
Down bool //可下载
Del bool //可删除
} type Updir []Upfile //表示一个目录当中,所有上传的文件
// 用Len Less Swap使Updir可排序,可用sort.Sort排序
func (d Updir) Len() int { return len(d) } // Date降序
func (d Updir) Less(i, j int) bool {
return d[i].Date > d[j].Date
} // 交换
func (d Updir) Swap(i, j int) { d[i], d[j] = d[j], d[i] } func main() {
fmt.Println("OK!请访问 :8080/share")
//启动一个http 服务器
app := iris.New()
//静态文件服务
app.StaticWeb("/share", "./share")
//注册视图目录
tmpl := iris.HTML("./v", ".html")
app.RegisterView(tmpl)
//主页
app.Get("/share", func(ctx iris.Context) {
ctx.View("main.html")
})
//下载
app.Get("/share/{path:alphabetical}", func(ctx iris.Context) {
FlagAllowDel := false //允许删除文件标志
//URL中的路径
reqPath := ctx.Path() //如:/share/aaa
myfolder := "." + reqPath + "/" //如:./share/aaa/
//获取执行文件路径:
rootdir, err := filepath.Abs(filepath.Dir(os.Args[])) //如:e:\goapp\myapp
createf := rootdir + reqPath + "/" //如:e:\goapp\myapp/share/aaa/
_, err = os.Stat(createf) //os.Stat获取文件信息
//判断文件夹path存在,否则创建之 ,绝对路径
if os.IsNotExist(err) {
os.MkdirAll(createf, os.ModePerm)
}
//列出目录下的文件
var upfile Upfile
fileins := make(Updir, )
files, _ := ioutil.ReadDir(myfolder)
for _, file := range files {
if file.IsDir() {
continue
} else {
upfile.Name = file.Name()
upfile.Url = ctx.Path() + "/" + file.Name()
upfile.Date = file.ModTime().Format("2006-01-02 15:04:05")
fileins = append(fileins, upfile)
}
}
//fmt.Println(fileins[0].Name)
//倒序排序
sort.Sort(fileins)
ctx.ViewData("FlagAllowDel", FlagAllowDel)
ctx.ViewData("Files", fileins)
// 渲染视图文件: ./v/index.html
ctx.View("share.html") })
//主页管理,与主页共用模板 .v/share.html
app.Get("/admin/{path:alphabetical}", func(ctx iris.Context) {
FlagAllowDel := true //允许删除文件标志
//列出目录下的文件
var upfile Upfile
fileins := make(Updir, )
myfolder := "./share" + ctx.Path()[:] + "/"
files, _ := ioutil.ReadDir(myfolder)
for _, file := range files {
if file.IsDir() {
continue
} else {
upfile.Name = file.Name()
upfile.Url = ctx.Path() + "/" + file.Name()
upfile.Date = file.ModTime().Format("2006-01-02 15:04:05")
fileins = append(fileins, upfile)
}
}
//fmt.Println(fileins[0].Name)
//倒序排序
sort.Sort(fileins)
ctx.ViewData("FlagAllowDel", FlagAllowDel)
ctx.ViewData("Files", fileins)
// 渲染视图文件: ./v/index.html
ctx.View("share.html") })
//上传, 接收用XMLHttpRequest上传的文件
app.Post("/share/{path:alphabetical}", func(ctx iris.Context) {
//获取文件内容
file, head, err := ctx.FormFile("upfile")
//可参考Get时的路径判断pathwww是否存在,这里省略了...
myfolder := "." + ctx.Path() + "/"
defer file.Close()
//创建文件
fW, err := os.Create(myfolder + head.Filename) if err != nil {
fmt.Println("文件创建失败")
return
}
defer fW.Close()
_, err = io.Copy(fW, file)
if err != nil {
fmt.Println("文件保存失败")
return
}
ctx.JSON(iris.Map{"success": true, "res": head.Filename}) })
//下载,未使用
app.Get("/share/down", func(ctx iris.Context) {
//无效ctx.Header("Content-Disposition", "attachment;filename=FileName.txt")
ctx.ServeFile("./share/1.txt", false)
})
//删除
app.Post("/admin/{dir}", func(ctx iris.Context) {
path := ctx.PostValue("path") //如 /admin/aaa/111.txt
myfolder := "./share" + path[:]
fmt.Println(myfolder)
os.Remove(myfolder)
ctx.JSON(iris.Map{"success": true, "res": "aaaaaaaaaaaa"}) }) app.Run(iris.Addr(":8080"))
}

share.html

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>{{.Title}}</title>
<style>
.file_upload_box {
display: inline-block;
width: 200px;
height: 50px;
position: relative;
overflow: hidden;
}
.file_upload_box input[type=file] {
position: absolute;
left: ;
top: ;
width: %;
line-height: 50px;
opacity: ;
cursor: pointer;
}
.file_upload_box a {
display: inline-block;
width: %;
line-height: 50px;
text-align: center;
font-family: "Microsoft yahei";
background-color: #f60;
color: #FFF;
font-weight: ;
text-decoration: none;
}
.flexcontainer{
display:flex;
}
</style> </head>
<body>
<div class="flexcontainer">
{{if $.FlagAllowDel}}
<span>管理面板</span>
{{else}}
<div id="fileSpan" style="background-color:#FFE;width:100%;height:50px">请将文件拖到这里上传(覆盖同名文件)</div>
<div class="file_upload_box">
<input type="file" name="file" onchange="upload(this)"/>
<a href="#none">上传文件</a>
</div>
{{end}} </div>
<script type="text/javascript">
window.onload = function(){
var uuz = document.getElementById('fileSpan'); uuz.ondragenter = function(e){
e.preventDefault();
} uuz.ondragover = function(e){
e.preventDefault();
this.innerHTML = '请松开鼠标';
this.style.cssText="background-color:#EFF;width:100%;height:50px;"
} uuz.ondragleave = function(e){
e.preventDefault();
this.innerHTML = '请将文件拖到这里上传';
this.style.cssText="background-color:#FFE;width:100%;height:50px;"
} uuz.ondrop = function(e){
e.preventDefault();
this.innerHTML = '请将文件拖到这里上传'; var upfile = e.dataTransfer.files[]; //获取要上传的文件对象(可以上传多个)
// alert(upfile.name)
//alert(upfile.type)
var formdata = new FormData();
var xhr = new XMLHttpRequest();
formdata.append('upfile', upfile); //设置服务器端接收的name为upfile
xhr.open("post","");
xhr.onreadystatechange = function(){
if(this.readyState==){
if(this.status==){ //上传成功
var resultText = this.responseText;
console.info(resultText);
//转json
var jsonObj = JSON.parse(resultText);
console.info(jsonObj);
if(jsonObj.success){
//var oUl = document.getElementById('ul1');
//var oLi = document.createElement('li');
//var oSpan = document.createElement('span');
//oSpan.innerHTML = jsonObj.res +"&nbsp;&nbsp;&nbsp;刚才上传";
//oLi.appendChild(oSpan);
//oUl.insertBefore(oLi, oUl.children[0]);
//刷新
window.location.reload(); }
}else{
alert('上传失败,请使用另一种方式上传');
}
}
} xhr.send(formdata);
}
}
function upload(e){
var upfile = e.files[];
var formdata = new FormData();
var xhr = new XMLHttpRequest();
formdata.append('upfile', upfile); //设置服务器端接收的name为upfile
xhr.open("post","");
xhr.onreadystatechange = function(){
if(this.readyState==){
if(this.status==){ //上传成功
var resultText = this.responseText;
//转json
var jsonObj = JSON.parse(resultText);
console.info(jsonObj);
if(jsonObj.success){
//刷新
window.location.reload(); }
}
}
}
xhr.send(formdata);
}
</script>
<div><a href="/share">返回总目录</a>&nbsp;&nbsp;-&nbsp;&nbsp;本目录文件</div>
<ul id="ul1" > {{range $i, $v := .Files}}
<li style="line-height:200%">
<span>&nbsp;{{$v.Name}}&nbsp;&nbsp;&nbsp;</span>
<span>&nbsp;{{$v.Date}}&nbsp;&nbsp;&nbsp;</span>
{{if $.FlagAllowDel}}
<span>&nbsp;<a href='#' onclick="del({{$v.Url}})" >删除</a>&nbsp;&nbsp;&nbsp;</span>
{{else}}
<span>&nbsp;<a href={{$v.Url}} download={{$v.Name}}>下载</a>&nbsp;&nbsp;&nbsp;</span>
{{end}}
</li>
{{end}}
</ul>
<script type="text/javascript">
function del(path){
//alert(path);
var formdata = new FormData();
var xhr = new XMLHttpRequest();
formdata.append('path', path); //设置服务器端接收
xhr.open("post","");
xhr.onreadystatechange = function(){
if(this.readyState==){
if(this.status==){ //成功
window.location.reload();
}
}else{
//alert('删除失败');
}
}
xhr.send(formdata);
}
</script>
</body>
</html>

参考:https://blog.csdn.net/fyxichen/article/details/60570484

用go iris 写的一个网页版文件共享应用(webapp)的更多相关文章

  1. 自己写一个网页版的Markdown实时编辑器

    这几天忙着使用Python+Django+sqlite 搭建自己的博客系统,但是单纯的使用H5的TextArea,简直太挫了有木有.所以,就想模仿一下人家内嵌到网页上的Markdown编辑器,从而让自 ...

  2. 用原生JS写一个网页版的2048小游戏(兼容移动端)

    这个游戏JS部分全都是用原生JS代码写的,加有少量的CSS3动画,并简单的兼容了一下移动端. 先看一下在线的demo:https://yuan-yiming.github.io/2048-online ...

  3. [Backbone.js]如何用backbone写一个仿网页版微信的webapp?

    var Chat = Backbone.Model.extend({ idAttribute:'id', initialize:function(options){ var users = this. ...

  4. nodejs写的一个网页爬虫例子(坏链率)

    因为工作需要,用nodejs写了个简单的爬虫例子,之前也没用过nodejs,连搭环境加写大概用了5天左右,so...要多简陋有多简陋,放这里给以后的自己看~~ 整体需求是:给一个有效的URL地址,返回 ...

  5. CAD使用SetxDataLong写数据(网页版)

    主要用到函数说明: MxDrawEntity::SetxDataLong 写一个long扩展数据,详细说明如下: 参数 说明 [in] BSTR val 字符串值 szAppName 扩展数据名称 n ...

  6. CAD使用SetxDataDouble写数据(网页版)

    主要用到函数说明: MxDrawEntity::SetxDataDouble 写一个Double扩展数据,详细说明如下: 参数 说明 [in] BSTR val 字符串值 szAppName 扩展数据 ...

  7. CAD使用SetxDataString写数据(网页版)

    主要用到函数说明: MxDrawEntity::SetxDataString 写一个字符串扩展数据,详细说明如下: 参数 说明 [in] BSTR val 字符串值 szAppName 扩展数据名称 ...

  8. 教你用纯Java实现一个网页版的Xshell(附源码)

    前言 最近由于项目需求,项目中需要实现一个WebSSH连接终端的功能,由于自己第一次做这类型功能,所以首先上了GitHub找了找有没有现成的轮子可以拿来直接用,当时看到了很多这方面的项目,例如:Gat ...

  9. CAD使用SetXData写数据(网页版)

    主要用到函数说明: MxDrawEntity::SetXData 设置实体的扩展数据,详细说明如下: 参数 说明 [in] IMxDrawResbuf* pXData 扩展数据链表 js代码实现如下: ...

随机推荐

  1. 超级实用的 Java 工具类

    超级实用的 Java 工具类 在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用最频繁及最通用的Java工具类.以下工具类.方法按使用流行度排名,参考数据来源于Github上随机选取 ...

  2. 深入15个HTML元素方法,你见过吗?

    虽然现代化的 web 开发更多地依赖各种 MVC 框架,但开发者仍需要熟练掌握 HTML 与 DOM 方面的基础知识.不过,即使是有着多年经验的前端开发者,也会遇到一些不明所以的情况.本文首先将为初学 ...

  3. Eclipse怎么改变@author 姓名

    1 点击windows  然后选择 点击进去选择搜索code Templates  点击选择出现下面的页面 点开comments,里面有给方法,变量 ,类等加注释设置的模板 如:点击Methods  ...

  4. join函数详解

    定义:join() 方法用于把数组中的所有元素放入一个字符串. 语法 : ArrayObject.join(separator)   separator 可选.指定要使用的分隔符.如果省略该参数,则使 ...

  5. [leetcode] 题解记录 1-10

    博客园markdown太烂, 题解详见https://github.com/TangliziGit/leetcode/blob/master/solution/1-10.md Leetcode Sol ...

  6. vue入门:(事件处理)

    基本应用 修饰符 为什么要在HTML中使用事件监听 Demo 一.基本应用 1.通过v-on指令绑定事件,例如: <button v-on:click="">提交< ...

  7. Python字符串、组合数据类型练习

    一.Python字符串练习 1.http://news.gzcc.cn/html/2017/xiaoyuanxinwen_1027/8443.html 取得校园新闻的编号. (这个方法就很多了,一般方 ...

  8. XSS防御和绕过1

    原理:对用户输入没做过滤和处理,是用户可以输入一些东西(例如js),控制输出达到一些攻击目的 1.DOM型 基于DOM的XSS有时也称为type0XSS.当用户能够通过交互修改浏览器页面中的DOM(D ...

  9. git 多账户添加ssh秘钥

    生成秘钥的步骤: ssh-keygen -t rsa -C "xxxx@qq.com" 添加秘钥 在不同的域中添加相同的秘钥是没有问题的,比如 github.com / code. ...

  10. JavaMaven【五、Maven集成Eclipse使用】

    创建Maven项目 右键->new->other(Ctrl+n)->Maven Project->quickStart(catalog) 执行指令 右键->Run As- ...