Swift - 做一个简单的无线U盘(手机端Http服务器搭建)
手机的ip,就可以通过web页面的形式访问到这个软件的用户文档。同时在这个web页面里,直接可以进行文件的上传,下载,删除等操作。
1
|
# import "GCDAsyncSocket.h" |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
import UIKit import AssetsLibrary class ViewController : UIViewController { //文件操作类 var manager: NSFileManager ! //保存用户文档目录 var docPath: NSURL ! override func viewDidLoad() { super .viewDidLoad() // Do any additional setup after loading the view, typically from a nib. //设置用户文档路径 manager = NSFileManager .defaultManager() let urlsForDocDirectory = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) docPath = urlsForDocDirectory[0] as ! NSURL //设置Web服务器 let server = Server () dispatch_async(dispatch_get_global_queue( DISPATCH_QUEUE_PRIORITY_BACKGROUND , 0), { () -> Void in server.addPostRequestHandler( Middleware .requestLogger( println )) //首页请求 server. get ( "/" ) { request, response, callback in self .createIndexHtml() let file = self .docPath. URLByAppendingPathComponent ( "index.html" ) let data = self .manager.contentsAtPath(file.path!) response.body = data callback(. Send (request, response)) } //文件请求 server. get ( "/file" ) { request, response, callback in println (request.arguments) var fileName = request.arguments[ "fileName" ] let file = self .docPath. URLByAppendingPathComponent (fileName!) let data = self .manager.contentsAtPath(file.path!) response.body = data callback(. Send (request, response)) } //启动并监听服务器 server.startListening(port: 4000, forever: true ) { result in switch result { case . Success : println ( "Up and running" ) case . Error ( let e): println ( "Server start failed \(e)" ) } } }) } //加载用户文档下的文件,并生成index.html首页 func createIndexHtml()-> Void { var content = "<html><meta charset=\"utf-8\"><body>" let contentsOfPath = manager.contentsOfDirectoryAtPath(docPath.path!, error: nil ) for child in contentsOfPath!{ content = content + "<a target='_blank' href='/file?fileName=\(child)'>\(child)</a><br/>" } content = content + "</body></html>" createFile( "index.html" , fileBaseUrl: docPath, content:content) } //创建文件 func createFile(name: String ,fileBaseUrl: NSURL ,content: String ){ var error: NSErrorPointer = nil let file = fileBaseUrl. URLByAppendingPathComponent (name) println ( "文件: \(file)" ) let exist = manager.fileExistsAtPath(file.path!) if !exist { var error: NSErrorPointer = nil manager.removeItemAtPath(file.path!, error:error) } let data = content.dataUsingEncoding( NSUTF8StringEncoding , allowLossyConversion: true ) let createSuccess = manager.createFileAtPath(file.path!,contents:data, attributes: nil ) println ( "文件创建结果: \(createSuccess)" ) } override func didReceiveMemoryWarning() { super .didReceiveMemoryWarning() // Dispose of any resources that can be recreated. } } |
调试说明:
Swift - 做一个简单的无线U盘(手机端Http服务器搭建)的更多相关文章
- C#做一个简单的进行串口通信的上位机
C#做一个简单的进行串口通信的上位机 1.上位机与下位机 上位机相当于一个软件系统,可以用于接收数据.控制数据.即可以对接收到的数据直接发送操控命令来操作数据.上位机可以接收下位机的信号.下位机是 ...
- 【Bugly干货分享】一起用 HTML5 Canvas 做一个简单又骚气的粒子引擎
Bugly 技术干货系列内容主要涉及移动开发方向,是由Bugly邀请腾讯内部各位技术大咖,通过日常工作经验的总结以及感悟撰写而成,内容均属原创,转载请标明出处. 前言 好吧,说是“粒子引擎”还是大言不 ...
- 使用React并做一个简单的to-do-list
1. 前言 说到React,我从一年之前就开始试着了解并且看了相关的入门教程,而且还买过一本<React:引领未来的用户界面开发框架 >拜读.React的轻量组件化的思想及其virtual ...
- 【 D3.js 入门系列 --- 3 】 做一个简单的图表!
前面说了几节,都是对文字进行处理,这一节中将用 D3.js 做一个简单的柱形图. 做柱形图有很多种方法,比如用 HTML 的 div 标签,或用 svg . 推荐用 SVG 来做各种图形.SVG 意为 ...
- 一起用HTML5 canvas做一个简单又骚气的粒子引擎
前言 好吧,说是"粒子引擎"还是大言不惭而标题党了,离真正的粒子引擎还有点远.废话少说,先看demo 本文将教会你做一个简单的canvas粒子制造器(下称引擎). 世界观 这个简单 ...
- Jmeter初步使用二--使用jmeter做一个简单的性能测试
经过上一次的初步使用,我们懂得了Jmeter的安装与初步使用的方法.现在,我们使用Jmeter做一个简单的性能测试.该次测试,提交的参数不做参数化处理,Jmeter各元件使用将在介绍在下一博文开始介绍 ...
- 用EF DataBase First做一个简单的MVC3报名页面
使用EF DataBase First做一个简单的MVC3报名网站 ORM(Object Relational Mapping)是面向对象语言中的一种数据访问技术,在ASP.NET中,可以通过ADO. ...
- 【 D3.js 入门系列 — 3 】 做一个简单的图表!
图1. 柱形图 1. 柱形图 前几章的例子,都是对文字进行处理.本章中将用 D3 做一个简单的柱形图.制作柱形图有很多种方法,比如用 HTML 的 <div> 标签,或在 SVG 上绘制 ...
- Windows Phone开发(21):做一个简单的绘图板
原文:Windows Phone开发(21):做一个简单的绘图板 其实我们今天要说的就是一个控件--InkPresenter,这个控件并不是十分强大,没办法和WPF中的InkCanvas相比,估计在实 ...
随机推荐
- 4.1 技术原理 & 4.2 键盘过滤框架
4.1 技术原理 & 4.2 键盘过滤框架 4.1 预备知识 符号链接:符号链接其实就是一个“别名”.可以用一个不同的名字来代表一个设备对象(实际上),符号链接可以指向任何有名字的对象. Zw ...
- HTML5新标签
<article>标签定义外部的内容.比如来自一个外部的新闻提供者的一篇新的文章,或者来自 blog 的文本,或者是来自论坛的文本.亦或是来自其他外部源内容. HTML5:<arti ...
- C语言深度剖析---const关键字(转载)
const是constant的缩写,是恒定不变的意思.被const修饰的值,是只读变量. 1.const修饰只读变量,具有不变性 #include <stdio.h> int m ...
- Android使用HttpClient向服务器传输文件
HttpClient是Apache Jakarta Common下的子项目,可以用来提供功能丰富的支持HTTP协议的客户端编程工具包,这几天写客户端的时候遇到个问题,“客户端需要向服务器发送Post请 ...
- get get_children方法
get 方法: [root@wx03 zook]# cat a4.pl use ZooKeeper; use AnyEvent; use AE; use Data::Dumper; my $zk = ...
- oschina 开发工具
开发工具 29反编译工具 26持续集成系统 19SQL注入工具 139Git开源工具 138Java开发工具 43.NET开发工具 85PHP开发工具 96C/C++开发工具 70Ruby/Rails ...
- 往Amazon上upload bundle经常中断的处理方法
首先可以按如下脚本进行重复提交 #!/bin/bash ;i<=;i=i+)) do ret1=`bin/ec2-upload-bundle -b myrawbucket -m /ec2-ami ...
- RelativeLayout的属性详解
1. android:layout_below="@+id/first" //在某元素的的下方: android:layout_alignBottom="@+id/fir ...
- AIDL使用详解
一.对AIDL进行说明 AIDL允许定义一个编程的接口来作为客户端和服务端通信的桥梁,AIDL定义了客户端和服务端的编程标准,在Android里边一个进程无法直接访问另一个进程的内存信息,但是要访问的 ...
- [转]PostgreSQL 中文资料汇总
原文链接:http://francs3.blog.163.com/blog/static/405767272014017341219/ --1 中文社区网站 PostgreSQL 中文社区官网: h ...