0 people like it.
Like the snippet!
Send file via HTML5 to Web server
Send file via HTML5 with a XMLHttpRequest to WebSharper Sitelet
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:
|
// client side
let getFiles () : FileList =
let input = JS.Document.GetElementById("uploadInput") |> As<HTMLInputElement>
input?files
let sendFiles (el:Dom.Element) (ev:Dom.Event) =
ev.PreventDefault()
JS.Document.GetElementById("response").InnerHTML <- ""
let oReq : XMLHttpRequest = JS.Inline("new XMLHttpRequest()") // WORKAROUND 1
let url = "/upload"
oReq.Open("POST",url, true)
oReq.Onload <- fun ev ->
Console.Log("Uploaded", ev)
oReq.Onerror <- fun ev ->
Console.Log("Error", ev)
oReq.Onreadystatechange <- fun ev ->
let response = oReq.StatusText + ": " + oReq.ResponseText
Console.Log(response)
if ([200; 400; 500] |> List.contains(oReq.Status)
&& not(System.String.IsNullOrWhiteSpace(oReq.ResponseText)) ) then
JS.Document.GetElementById("response").InnerHTML <- response
let files = getFiles ()
JS.Inline("$0.send($1)", oReq, files.[0]) // WORKAROUND 2
// server side
let StreamingUploadFilePage (ctx:Context<EndPoint>) =
try
let stream = ctx.Request.Body
if (stream.Length > (int64 0) && stream.Length < (int64 2.5E6)) then
let count = int stream.Length
let buffer = Array.zeroCreate<byte> count
let res = stream.Read(buffer, 0, count)
use fs = File.Open(destinationPath, FileMode.Create)
fs.Write(buffer, 0, count)
Content.Text ("Uploaded! (" + res.ToString() + ")")
else
Content.Text ("File Size is not permitted: " + stream.Length.ToString())
|> Content.SetStatus (Http.Status.Custom 400 (Some "Bad Request"))
with
|exc ->
Content.Text exc.Message
|> Content.SetStatus Http.Status.InternalServerError
|
val getFiles : unit -> obj
Full name: Script.getFiles
val input : obj
val sendFiles : el:'a -> ev:'b -> 'c
Full name: Script.sendFiles
val el : 'a
val ev : 'b
Multiple items
module Event
from Microsoft.FSharp.Control
--------------------
type Event<'T> =
new : unit -> Event<'T>
member Trigger : arg:'T -> unit
member Publish : IEvent<'T>
Full name: Microsoft.FSharp.Control.Event<_>
--------------------
type Event<'Delegate,'Args (requires delegate and 'Delegate :> Delegate)> =
new : unit -> Event<'Delegate,'Args>
member Trigger : sender:obj * args:'Args -> unit
member Publish : IEvent<'Delegate,'Args>
Full name: Microsoft.FSharp.Control.Event<_,_>
--------------------
new : unit -> Event<'T>
--------------------
new : unit -> Event<'Delegate,'Args>
val oReq : obj
val url : string
Multiple items
module List
from Microsoft.FSharp.Collections
--------------------
type List<'T> =
| ( [] )
| ( :: ) of Head: 'T * Tail: 'T list
interface IEnumerable
interface IEnumerable<'T>
member GetSlice : startIndex:int option * endIndex:int option -> 'T list
member Head : 'T
member IsEmpty : bool
member Item : index:int -> 'T with get
member Length : int
member Tail : 'T list
static member Cons : head:'T * tail:'T list -> 'T list
static member Empty : 'T list
Full name: Microsoft.FSharp.Collections.List<_>
val contains : value:'T -> source:'T list -> bool (requires equality)
Full name: Microsoft.FSharp.Collections.List.contains
val not : value:bool -> bool
Full name: Microsoft.FSharp.Core.Operators.not
namespace System
Multiple items
type String =
new : value:char -> string + 7 overloads
member Chars : int -> char
member Clone : unit -> obj
member CompareTo : value:obj -> int + 1 overload
member Contains : value:string -> bool
member CopyTo : sourceIndex:int * destination:char[] * destinationIndex:int * count:int -> unit
member EndsWith : value:string -> bool + 2 overloads
member Equals : obj:obj -> bool + 2 overloads
member GetEnumerator : unit -> CharEnumerator
member GetHashCode : unit -> int
...
Full name: System.String
--------------------
System.String(value: nativeptr<char>) : unit
System.String(value: nativeptr<sbyte>) : unit
System.String(value: char []) : unit
System.String(c: char, count: int) : unit
System.String(value: nativeptr<char>, startIndex: int, length: int) : unit
System.String(value: nativeptr<sbyte>, startIndex: int, length: int) : unit
System.String(value: char [], startIndex: int, length: int) : unit
System.String(value: nativeptr<sbyte>, startIndex: int, length: int, enc: System.Text.Encoding) : unit
System.String.IsNullOrWhiteSpace(value: string) : bool
val files : obj
val StreamingUploadFilePage : ctx:'a -> 'b
Full name: Script.StreamingUploadFilePage
val ctx : 'a
val stream : obj
Multiple items
val int64 : value:'T -> int64 (requires member op_Explicit)
Full name: Microsoft.FSharp.Core.Operators.int64
--------------------
type int64 = System.Int64
Full name: Microsoft.FSharp.Core.int64
--------------------
type int64<'Measure> = int64
Full name: Microsoft.FSharp.Core.int64<_>
val count : int
Multiple items
val int : value:'T -> int (requires member op_Explicit)
Full name: Microsoft.FSharp.Core.Operators.int
--------------------
type int = int32
Full name: Microsoft.FSharp.Core.int
--------------------
type int<'Measure> = int
Full name: Microsoft.FSharp.Core.int<_>
val buffer : byte []
module Array
from Microsoft.FSharp.Collections
val zeroCreate : count:int -> 'T []
Full name: Microsoft.FSharp.Collections.Array.zeroCreate
Multiple items
val byte : value:'T -> byte (requires member op_Explicit)
Full name: Microsoft.FSharp.Core.Operators.byte
--------------------
type byte = System.Byte
Full name: Microsoft.FSharp.Core.byte
val res : obj
val fs : System.IDisposable
System.Object.ToString() : string
union case Option.Some: Value: 'T -> Option<'T>
val exc : exn
property System.Exception.Message: string
More information