nginx开放webdav,openwrt专用,kodi可用。
简介:
webdav是基于HTTP的扩展协议,类似FTP了,可以上传,可以下载。
我现在有一个openwrt,有2G内存,500G硬盘,挂了aria2下载电影。
平时习惯用kodi通过samba看电影,可是还是有点不方便,只能局域网,并不能广域网,这个webdav,就可以突破samba的限制,实现广域网访问了。
反正公网IPV6也调试完成,把家,办公室,父母家都连起来吧。
一:openwrt的IPV6
这个可以翻前面的文章,不赘述了。
二:openwrt,安装nginx
opkg update opkg remove nginx luci-ssl-nginx nginx-util nginx-ssl --force-depends opkg install nginx-all-module opkg install luci-ssl-nginx
三:方法一:增加端口访问
1.增加webdav账号密码
echo "admin:$(openssl passwd 123456)" >/etc/nginx/conf.d/.davpasswd
2.配置共享目录及权限
本例目录是/storage/data/share
mkdir /storage mkdir /storage/data mkdir /storage/data/share chown -R nobody:nogroup /storage/data/share/ chmod -R 700 /storage/data/share/
3.配置nginx配置文件
增加一个配置文件/etc/nginx/conf.d/webdav.conf
本例端口是8080
server { listen 8080; listen [::]:8080; server_name _; charset utf-8; location / { root /storage/data/share; if ($request_method = MKCOL) { # 解决 MKCOL 需要以'/'结尾 rewrite ^(.*[^/])$ $1/ break; } dav_methods PUT DELETE MKCOL COPY MOVE; dav_ext_methods PROPFIND OPTIONS; dav_access user:rw group:rw all:r; auth_basic "Authorized Users WebDAV"; auth_basic_user_file /etc/nginx/conf.d/.davpasswd; } }
4.测试nginx配置文件
nginx -t -c /etc/nginx/uci.conf
nginx: configuration file /etc/nginx/uci.conf test is successful
successful就是通过测试
5.重启nginx
root@OpenWrt:~# /etc/init.d/nginx reload
root@OpenWrt:~# /etc/init.d/nginx restart
没报错就是好的。
6.测试webdav
用winscp来测试,我是没通过那个windows映射磁盘,也不知道为什么。
四:方法二:增加路径访问
其实就是nginx的配置文件不同:
配置失败,也许是winscp不支持带路径的webdav。
windows映射磁盘失败。
五:方法三:增加域名访问
还是nginx的配置文件不同:
删除listen
配置server_name为你的域名,并将域名解析到这个openwrt上即可。
server { server_name test.jack.com; charset utf-8; location / { root /storage/data/share; if ($request_method = MKCOL) { # 解决 MKCOL 需要以'/'结尾 rewrite ^(.*[^/])$ $1/ break; } dav_methods PUT DELETE MKCOL COPY MOVE; dav_ext_methods PROPFIND OPTIONS; dav_access user:rw group:rw all:r; auth_basic "Authorized Users WebDAV"; auth_basic_user_file /etc/nginx/conf.d/.davpasswd; } }