HTTP: Difference between revisions
m
→{{header|Wren}}: Minor tidy
mNo edit summary |
m (→{{header|Wren}}: Minor tidy) |
||
(309 intermediate revisions by 42 users not shown) | |||
Line 3:
;Task:
Access and print a [[wp:Uniform Resource Locator|URL
There is a separate task for [[HTTPS Request]]s.
Line 9:
=={{header|8th}}==
<
"http://www.rosettacode.org" net:get drop >s .
</syntaxhighlight>
=={{header|ABAP}}==
This works for ABAP Version 7.40 and above
<syntaxhighlight lang="abap">
report z_http.
cl_http_client=>create_by_url(
exporting
url = `http://rosettacode.org/robots.txt`
importing
client = data(http_client)
exceptions
argument_not_found = 1
plugin_not_active = 2
internal_error = 3
others = 4 ).
if sy-subrc <> 0.
data(error_message) = switch string( sy-subrc
when 1 then `argument_not_found`
when 2 then `plugin_not_active`
when 3 then `internal_error`
when 4 then `other error` ).
write error_message.
exit.
endif.
data(rest_http_client) = cast if_rest_client( new cl_rest_http_client( http_client ) ).
rest_http_client->get( ).
data(response_string) = rest_http_client->get_response_entity( )->get_string_data( ).
split response_string at cl_abap_char_utilities=>newline into table data(output_table).
loop at output_table assigning field-symbol(<output_line>).
write / <output_line>.
endloop.
</syntaxhighlight>
{{out}}
<pre>
User-agent: *
Allow: /mw/images/
Allow: /mw/skins/
Allow: /mw/title.png
Allow: /mw/resources/
Disallow: /w/
Disallow: /mw/
Disallow: /wiki/Special:
</pre>
=={{header|ActionScript}}==
<
package
{
Line 36 ⟶ 89:
}
}
</syntaxhighlight>
=={{header|Ada}}==
{{libheader|AWS}}
<
with Ada.Text_IO; use Ada.Text_IO;
Line 50 ⟶ 103:
Put_Line (AWS.Response.Message_Body (AWS.Client.Get (URL => "http://www.rosettacode.org")));
end HTTP_Request;
</syntaxhighlight>
=={{header|ALGOL 68}}==
Line 58 ⟶ 111:
{{wont work with|ELLA ALGOL 68|Any (with appropriate job cards) - tested with release [http://sourceforge.net/projects/algol68/files/algol68toc/algol68toc-1.8.8d/algol68toc-1.8-8d.fc9.i386.rpm/download 1.8-8d] - due to extensive use of ''grep in string'' and ''http content''}}
<
STRING domain="rosettacode.org";
STRING page="wiki/Main_Page";
Line 88 ⟶ 141:
ELSE print (strerror (rc))
FI
</syntaxhighlight>
=={{header|Amazing Hopper}}==
<syntaxhighlight lang="amazing hopper">
#include <hopper.h>
main:
s=`curl -s -L https://rosettacode.org/wiki/HTTP`
{s}len, lenght=0, mov(lenght)
{"Size = ",lenght,"\nContent = \n",s}println
exit(0)
</syntaxhighlight>
{{out}}
<pre>
Size = 402474
Content =
<!DOCTYPE html>
<html lang="en" dir="ltr" class="client-nojs">
<head>
<meta charset="UTF-8" />
...
</pre>
=={{header|Arturo}}==
<syntaxhighlight lang="rebol">print read "http://rosettacode.org"</syntaxhighlight>
=={{header|AutoHotkey}}==
<syntaxhighlight lang="autohotkey">
UrlDownloadToFile, http://rosettacode.org, url.html
Run, cmd /k type url.html
</syntaxhighlight>
=={{header|AWK}}==
{{works with|gawk}}
<
site="en.wikipedia.org"
path="/wiki/"
Line 117 ⟶ 193:
print ship
}</
=={{header|BaCon}}==
<syntaxhighlight lang="qbasic">'
' Read and display a website
'
IF AMOUNT(ARGUMENT$) = 1 THEN
website$ = "www.basic-converter.org"
ELSE
website$ = TOKEN$(ARGUMENT$, 2)
ENDIF
OPEN website$ & ":80" FOR NETWORK AS mynet
SEND "GET / HTTP/1.1\r\nHost: " & website$ & "\r\n\r\n" TO mynet
REPEAT
RECEIVE dat$ FROM mynet
total$ = total$ & dat$
UNTIL ISFALSE(WAIT(mynet, 500))
CLOSE NETWORK mynet
PRINT total$
</syntaxhighlight>
=={{header|Batch File}}==
<
curl.exe -s -L http://rosettacode.org/
</syntaxhighlight>
=={{header|BBC BASIC}}==
{{works with|BBC BASIC for Windows}}
<
SYS "GetProcAddress", urlmon%, "URLDownloadToFileA" TO URLDownloadToFile
Line 134 ⟶ 230:
IF fail% ERROR 100, "File download failed"
OSCLI "TYPE """ + file$ + """"</
=={{header|Biferno}}==
simple one-liner using httpExt and quick print $
<
=={{header|C}}==
{{libheader|libcurl}}
<syntaxhighlight lang="c">
#include <stdio.h>
#include <stdlib.h>
Line 166 ⟶ 262:
return EXIT_SUCCESS;
}
</syntaxhighlight>
=={{header|C sharp}}==
<syntaxhighlight lang="csharp">
using System;
using System.Text;
using System.Net;
class Program
{
static void Main(string[] args)
{
WebClient wc = new WebClient();
string content = wc.DownloadString("http://www.google.com");
Console.WriteLine(content);
}
}
</syntaxhighlight>
=={{header|C++}}==
<
#include <winsock2.h>
#include <ws2tcpip.h>
Line 208 ⟶ 321:
return 0;
}
</syntaxhighlight>
{{libheader|U++}}
<
#include <Web/Web.h>
Line 221 ⟶ 334:
Cout() << HttpClient("www.rosettacode.org").ExecuteRedirect();
}
</syntaxhighlight>
=={{header|Caché ObjectScript}}==
Line 248 ⟶ 344:
USER>Do HttpRequest.HttpResponse.Data.OutputToDevice()
</pre>
=={{header|Clojure}}==
Using the Java API:
<
(defn get-http [url]
(let [sc (java.util.Scanner.
Line 259 ⟶ 354:
(println (.nextLine sc)))))
(get-http "http://www.rosettacode.org")
</syntaxhighlight>
Using <code>clojure.contrib.http.agent</code>:
<
(ns example
(:use [clojure.contrib.http.agent :only (string http-agent)]))
(println (string (http-agent "http://www.rosettacode.org/")))
</syntaxhighlight>
{{works with|Clojure|1.2}}
<
(print (slurp "http://www.rosettacode.org/"))
</syntaxhighlight>
=={{header|COBOL}}==
Line 278 ⟶ 373:
Tested with GnuCOBOL
<
identification division.
program-id. curl-rosetta.
Line 569 ⟶ 664:
goback.
end program curl-write-callback.</
and a copybook
<
*> Usage: COPY occurlsym inside data division
*> Taken from include/curl/curl.h 2013-12-19
Line 764 ⟶ 859:
03 FILLER PIC X(30) VALUE "CURLE_AGAIN ".
01 FILLER REDEFINES LIBCURL_ERRORS.
02 CURLEMSG OCCURS 81 TIMES PIC X(30).</
{{out}}
Line 779 ⟶ 874:
=={{header|ColdFusion}}==
<
<cfhttp url="http://www.rosettacode.org" result="result">
<cfoutput>#result.FileContent#</cfoutput>
</syntaxhighlight>
=={{header|Common Lisp}}==
CLISP provides an extension function to read http sources. Other implementations may do this differently.
{{works with|CLISP}}
<
(defun wget-clisp (url)
(ext:with-http-input (stream url)
Line 793 ⟶ 888:
while line
do (format t "~a~%" line))))
</syntaxhighlight>
{{libheader|DRAKMA}}
Line 799 ⟶ 894:
First grabbing the entire body as a string, and then by pulling from a stream (as in the CLISP example).
<
(defun wget-drakma-string (url &optional (out *standard-output*))
"Grab the body as a string, and write it to out."
Line 810 ⟶ 905:
while line do (write-line line out)
finally (close body)))
</syntaxhighlight>
{{libheader|Dexador}}
<syntaxhighlight lang="lisp">
(format t "~a~%" (nth-value 0 (dex:get "http://www.w3.org/")))
</syntaxhighlight>
=={{header|Crystal}}==
<syntaxhighlight lang="crystal">
require "http/client"
HTTP::Client.get("http://google.com")
</syntaxhighlight>
=={{header|D}}==
{{libheader|phobos}}
<syntaxhighlight lang="d">
void main() {
import std.stdio, std.net.curl;
writeln(get("http://google.com"));
}
</syntaxhighlight>
{{libheader|tango}}
<syntaxhighlight lang="d">
import tango.io.Console;
import tango.net.http.HttpGet;
Line 831 ⟶ 938:
Cout.stream.copy( (new HttpGet("http://google.com")).open );
}
</syntaxhighlight>
Or more operating directly on the socket:
<syntaxhighlight lang="d">
import tango.io.Console;
import tango.net.InternetAddress;
Line 846 ⟶ 953:
Cout.stream.copy (site);
}
</syntaxhighlight>
=={{header|Dart}}==
Using the stand-alone VM:
<
void main(){
var url = 'http://rosettacode.org';
Line 857 ⟶ 964:
.then((HttpClientRequest request) => request.close())
.then((HttpClientResponse response) => response.pipe(stdout));
}</
=={{header|Delphi}}==
Simple example using the free Synapse TCP/IP library [http://www.ararat.cz/synapse/doku.php/download]
<syntaxhighlight lang="delphi">
program HTTP;
Line 906 ⟶ 1,013:
end.
</syntaxhighlight>
Using Indy:
<syntaxhighlight lang="delphi">
program ShowHTTP;
Line 931 ⟶ 1,038:
end;
end.
</syntaxhighlight>
=={{header|Dragon}}==
<syntaxhighlight lang="dragon">select "http"
select "std"
http("http://www.rosettacode.org", ::echo)
</syntaxhighlight>
=={{header|E}}==
<syntaxhighlight lang="e">
when (def t := <http://www.rosettacode.org> <- getText()) -> {
println(t)
}
</syntaxhighlight>
=={{header|EchoLisp}}==
'''file->string''' usage: the server must allow cross-domain access, or a browser add-on like cors-everywhere must be installed to bypass cross-domain checking.
<
;; asynchronous call back definition
(define (success name text) (writeln 'Loaded name) (writeln text))
;;
(file->string success "http://www.google.com")
</syntaxhighlight>
=={{header|Emacs Lisp}}==
{{libheader|url.el}}
<code>url-retrieve-synchronously</code> returns a buffer containing headers and body. Caller must kill the buffer when no longer needed.
<syntaxhighlight lang="lisp">(let ((buffer (url-retrieve-synchronously "http://www.rosettacode.org")))
(unwind-protect
(with-current-buffer buffer
(message "%s" (buffer-substring url-http-end-of-headers (point-max))))
(kill-buffer buffer)))</syntaxhighlight>
Asynchronously (buffer doesn't need to be killed by caller):
<syntaxhighlight lang="lisp">(url-retrieve "http://www.rosettacode.org"
(lambda (_status)
(message "%s" (buffer-substring url-http-end-of-headers (point-max)))))</syntaxhighlight>
=={{header|Erlang}}==
===Synchronous===
<
-module(main).
-export([main/1]).
Line 972 ⟶ 1,095:
{error, Res} -> io:fwrite("~p~n", [Res])
end.
</syntaxhighlight>
===Asynchronous===
<
-module(main).
-export([main/1]).
Line 987 ⟶ 1,110:
after 10000 -> io:fwrite("Timed out.~n",[])
end.
</syntaxhighlight>
Using it
<
|escript ./req.erl http://www.rosettacode.org
</syntaxhighlight>
=={{header|F_Sharp|F#}}==
In F# we can just use the .NET library to do this so its the same as the [[C_sharp|C#]] example.
<
let wget (url : string) =
use c = new System.Net.WebClient()
Line 1,003 ⟶ 1,126:
printfn "%s" (wget "http://www.rosettacode.org/")
</syntaxhighlight>
However unlike C#, F# can use an asynchronous workflow to avoid blocking any threads while waiting for a response from the server. To asynchronously download three url's at once...
<
open System.Net
open System.IO
Line 1,022 ⟶ 1,145:
|> List.map wgetAsync
|> Async.Parallel
|> Async.RunSynchronously</
=={{header|Factor}}==
<
"http://www.rosettacode.org" http-get nip print
</syntaxhighlight>
=={{header|Forth}}==
{{works with|GNU Forth|0.7.0}}
This works at the socket level, returning both the HTTP headers and page contents.
<
include unix/socket.fs
Line 1,039 ⟶ 1,162:
dup pad 8092 read-socket type
close-socket
</syntaxhighlight>
=={{header|FreeBASIC}}==
<syntaxhighlight lang="freebasic">Dim As String urlfile
urlfile="start http://rosettacode.org/wiki/Main_Page"
Print urlfile
Shell(urlfile)
Print !"\n--- pulsa RETURN para continuar ---"
Sleep</syntaxhighlight>
=={{header|friendly interactive shell}}==
{{trans|UNIX Shell}}
<
<
<
<
{{works with|BSD}}
<
=={{header|Frink}}==
Frink's <CODE>read[<I>URL</I>]</CODE> function works with any URL type supported by your Java Virtual Machine, and returns the results as a single string.
<
print[read["http://
</syntaxhighlight>
=={{header|FutureBasic}}==
<syntaxhighlight lang="futurebasic">
include "NSLog.incl"
#plist NSAppTransportSecurity @{NSAllowsArbitraryLoads:YES}
local fn URLSessionHandler( session as URLSessionRef, dta as CFDataRef, response as URLResponseRef, err as ErrorRef, userData as ptr )
if ( fn HTTPURLResponseStatusCode( (HTTPURLResponseRef)response ) == 200 )
NSLog( @"%@", fn StringWithData( dta, NSUTF8StringEncoding ) )
else
NSLog( @"%@", fn ErrorLocalizedDescription( err ) )
end if
NSLogScrollToTop
end fn
local fn URLSessionWithGetRequest( path as CFStringRef )
CFURLRef url = fn URLWithString( path )
MutableURLRequestRef urlRequest = fn MutableURLRequestWithURL( url )
MutableURLRequestSetHTTPMethod( urlRequest, @"HTTP" )
URLSessionRef session = fn URLSessionSharedSession
URLSessionDataTaskRef task = fn URLSessionDataTaskWithRequestCompletionHandler( session, urlRequest, @fn URLSessionHandler, NULL )
URLSessionTaskResume( task )
end fn
fn URLSessionWithGetRequest( @"http://rosettacode.org" )
HandleEvents
</syntaxhighlight>
=={{header|Gastona}}==
<
<main>
LOOP, TEXT FILE, http://www.rosettacode.org
, BODY, @<value>
</syntaxhighlight>
=={{header|GML}}==
Line 1,072 ⟶ 1,237:
'''Any Event'''
<
'''HTTP Event'''
<
{
show_message_async(ds_map_find_value(async_load,"result"));
}</
=={{header|Go}}==
<syntaxhighlight lang="go">
package main
Line 1,098 ⟶ 1,263:
io.Copy(os.Stdout, r.Body)
}
</syntaxhighlight>
Output:
Line 1,112 ⟶ 1,277:
=={{header|Groovy}}==
<
new URL("http://www.rosettacode.org").eachLine { println it }
</syntaxhighlight>
=={{header|GUISS}}==
Line 1,120 ⟶ 1,285:
It would be more appropriate to paste to notepad:
<
Click:Area:browser window,Type:[Control A],[Control C],Start,Programs,Accessories,Notepad,
Menu:Edit,Paste</
=={{header|Halon}}==
<syntaxhighlight lang="halon">echo http("http://www.rosettacode.org");</syntaxhighlight>
=={{header|Haskell}}==
Using {{libheader|HTTP}} from [http://hackage.haskell.org/packages/hackage.html HackageDB]
<
import Network.Browser
import Network.HTTP
import Network.URI
main = do
rsp <- Network.Browser.browse $ do
setAllowRedirects True
setOutHandler $ const (return ())
request $ getRequest "http://www.rosettacode.org/"
putStrLn $ rspBody $ snd rsp
</syntaxhighlight>
== Icon and Unicon ==
==={{header|Icon}}===
<
link cfunc
procedure main(arglist)
Line 1,163 ⟶ 1,330:
while write(read(f))
end
</syntaxhighlight>
Using it
<
|icon req.icn http://www.rosettacode.org
</syntaxhighlight>
==={{header|Unicon}}===
Unicon provides improved socket and messaging support without the need for the external function ''cfunc'':
<
procedure main(arglist)
m := open(arglist[1],"m")
while write(read(m))
end
</syntaxhighlight>
=={{header|J}}==
Using <tt>gethttp</tt> from [[Web Scraping#J|Web Scraping]]
<
gethttp 'http://www.rosettacode.org'
</syntaxhighlight>
=={{header|Java}}==
The ''URL'' class offers an ''openStream'' method which will make a connection and return an ''InputStream''.
<syntaxhighlight lang="java">
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.URI;
import java.net.URISyntaxException;
import java.net.URL;
</syntaxhighlight>
<syntaxhighlight lang="java">
void printContent(String address) throws URISyntaxException, IOException {
URL url = new URI(address).toURL();
try (BufferedReader reader = new BufferedReader(new InputStreamReader(url.openStream()))) {
String line;
while ((line = reader.readLine()) != null)
System.out.println(line);
}
}
</syntaxhighlight>
<br />
Using the standard [http://openjdk.java.net/groups/net/httpclient/ Java 11 HTTP Client]
<syntaxhighlight lang="java">import java.net.URI;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;
import java.nio.charset.Charset;
public class Main {
public static void main(String[] args)
HttpClient.newHttpClient()
.sendAsync(request, HttpResponse.BodyHandlers.ofString(Charset.defaultCharset()))
.thenApply(HttpResponse::body)
.thenAccept(System.out::println)
.join();
}
}</syntaxhighlight>
{{libheader|Apache Commons IO}}
<
import org.apache.commons.io.IOUtils;
import java.net.URL;
Line 1,209 ⟶ 1,406:
IOUtils.copy(new URL("http://rosettacode.org").openStream(),System.out);
}
}</
=={{header|JavaScript}}==
===Browser===
Using fetch API and async/await:
<syntaxhighlight lang="javascript">
const response = await fetch('http://rosettacode.org');
const text = await response.text();
console.log(text);
</syntaxhighlight>
Using fetch API:
<syntaxhighlight lang="javascript">
fetch('http://rosettacode.org').then(function (response) {
return response.text();
}).then(function (text) {
console.log(text);
});
</syntaxhighlight>
<syntaxhighlight lang="javascript">var req = new XMLHttpRequest();
req.onload = function() {
console.log(this.responseText);
Line 1,218 ⟶ 1,433:
req.open('get', 'http://rosettacode.org', true);
req.send()</
As a repeatable function:
<syntaxhighlight lang="javascript">/**
* @name _http
* @description Generic API Client using XMLHttpRequest
* @param {string} url The URI/URL to connect to
* @param {string} method The HTTP method to invoke- GET, POST, etc
* @param {function} callback Once the HTTP request has completed, responseText is passed into this function for execution
* @param {object} params Query Parameters in a JavaScript Object (Optional)
*
*/
function _http(url, method, callback, params) {
var xhr,
reqUrl;
xhr = new XMLHttpRequest();
xhr.onreadystatechange = function xhrProc() {
if (xhr.readyState == 4 && xhr.status == 200) {
callback(xhr.responseText);
}
};
/** If Query Parameters are present, handle them... */
if (typeof params === 'undefined') {
reqUrl = url;
} else {
switch (method) {
case 'GET':
reqUrl = url + procQueryParams(params);
break;
case 'POST':
reqUrl = url;
break;
default:
}
}
/** Send the HTTP Request */
if (reqUrl) {
xhr.open(method, reqUrl, true);
xhr.setRequestHeader("Accept", "application/json");
if (method === 'POST') {
xhr.send(params);
} else {
xhr.send();
}
}
/**
* @name procQueryParams
* @description Return function that converts Query Parameters from a JavaScript Object to a proper URL encoded string
* @param {object} params Query Parameters in a JavaScript Object
*
*/
function procQueryParams(params) {
return "?" + Object
.keys(params)
.map(function (key) {
return key + "=" + encodeURIComponent(params[key])
})
.join("&")
}
}</syntaxhighlight>
Using jQuery:
<
console.log(data);
};</
===Node.js===
With Node.js, using only the included http module.
<syntaxhighlight lang="javascript">const http = require('http');
http.get('http://rosettacode.org', (resp) => {
let data = '';
// A chunk of data has been recieved.
resp.on('data', (chunk) => {
data += chunk;
});
// The whole response has been received. Print out the result.
resp.on('end', () => {
console.log("Data:", data);
});
}).on("error", (err) => {
console.log("Error: " + err.message);
});</syntaxhighlight>
=={{header|Jsish}}==
Based on Jsi_Wget that ships with Jsish.
<syntaxhighlight lang="javascript">#!/usr/bin/env jsish
function httpGet(fileargs:array|string, conf:object=void) {
var options = { // Web client for downloading files from url
headers : [], // Header fields to send.
nowait : false, // Just return object: caller will call update.
onDone : null, // Callback when done.
wsdebug : 0 // WebSockets debug level.
};
var self = {
address : '',
done : false,
path : '',
port : -1,
post : '', // Post file upload (UNIMPL).
scheme : 'http', // Url scheme
protocol : 'get',
url : null,
response : ''
};
parseOpts(self, options, conf);
if (self.port === -1)
self.port = 80;
function WsRecv(ws:userobj, id:number, str:string) {
LogDebug("LEN: "+str.length);
LogTrace("DATA", str);
self.response += str;
}
function WsClose(ws:userobj|null, id:number) {
LogDebug("CLOSE");
self.done = true;
if (self.onDone)
self.onDone(id);
}
function main() {
if (self.Debug)
debugger;
if (typeof(fileargs) === 'string')
fileargs = [fileargs];
if (!fileargs || fileargs.length !== 1)
throw("expected a url arg");
self.url = fileargs[0];
var m = self.url.match(/^([a-zA-Z]+):\/\/([^\/]*+)(.*)$/);
if (!m)
throw('invalid url: '+self.url);
self.scheme = m[1];
self.address = m[2];
self.path = m[3];
var as = self.address.split(':');
if (as.length==2) {
self.port = parseInt(as[1]);
self.address = as[0];
} else if (as.length != 1)
throw('bad port in address: '+self.address);
if (self.path=='')
self.path = '/index.html';
if (self.post.length)
self.protocol = 'post';
var wsopts = {
client:true,
onRecv:WsRecv,
onClose:WsClose,
debug:self.wsdebug,
rootdir:self.path,
port:self.port,
address:self.address,
protocol:self.protocol,
clientHost:self.address
};
if (self.post.length)
wsopts.post = self.post;
if (self.headers.length)
wsopts.headers = self.headers;
if (self.scheme === 'https') {
if (!Interp.conf('hasOpenSSL'))
puts('SSL is not compiled in: falling back to http:');
else {
if (self.port === 80)
wsopts.port = 441;
wsopts.use_ssl = true;
}
}
LogDebug("Starting:", conf, wsopts);
self.ws = new WebSocket( wsopts );
if (self.nowait)
return self;
while (!self.done) {
update(200);
LogTrace("UPDATE");
}
delete self.ws;
return self.response;
}
return main();
}
provide(httpGet, "0.60");
if (isMain())
runModule(httpGet);</syntaxhighlight>
{{out}}
<pre>prompt$ jsish
# require('httpGet')
0.6
# var page = httpGet('http://rosettacode.org/robots.txt')
variable
# page
"User-agent: *
Allow: /mw/images/
Allow: /mw/skins/
Allow: /mw/title.png
Allow: /mw/resources/
Disallow: /w/
Disallow: /mw/
Disallow: /wiki/Special:
"</pre>
=={{header|Julia}}==
<
readurl("http://rosettacode.org/index.html")</syntaxhighlight>
=={{header|Kotlin}}==
<syntaxhighlight lang="scala">// version 1.1.2
import java.net.URL
import java.io.InputStreamReader
import java.util.Scanner
fun main(args: Array<String>) {
val url = URL("http://www.puzzlers.org/pub/wordlists/unixdict.txt")
val isr = InputStreamReader(url.openStream())
val sc = Scanner(isr)
while (sc.hasNextLine()) println(sc.nextLine())
sc.close()
}</syntaxhighlight>
=={{header|Lasso}}==
incude_url is a wrapper for Lasso's curl datatype, however it can be achieved in several ways.
<
include_url('http://rosettacode.org/index.html')
Line 1,242 ⟶ 1,694:
local(x = curl('http://rosettacode.org/index'))
local(y = #x->result)
#y->asString</
=={{header|LFE}}==
===Synchronous===
<
(case (: httpc request '"http://lfe.github.io")
((tuple 'ok result)
Line 1,253 ⟶ 1,705:
((tuple 'error reason)
(: io format '"Error: ~p~n" (list reason))))
</syntaxhighlight>
===Asynchronous===
<
(let* ((method 'get)
(url '"http://lfe.github.io")
Line 1,269 ⟶ 1,721:
((tuple 'http (tuple request-id result))
(: io format '"Result: ~p~n" (list result))))))
</syntaxhighlight>
=={{header|Liberty BASIC}}==
Uses a dll call and a timer to allow time to receive the file.
<syntaxhighlight lang="lb">
result = DownloadToFile( "http://rosettacode.org/wiki/Main_Page", "in.html")
timer 2000, [on]
Line 1,294 ⟶ 1,746:
close #url
end function
</syntaxhighlight>
=={{header|Lingo}}==
Line 1,300 ⟶ 1,752:
Parent script "SimpleHttpGet":
<
property _cbHandler
property _cbTarget
Line 1,329 ⟶ 1,781:
call(me._cbHandler, me._cbTarget, res, err)
end if
end</
In some movie script:
<
--
----------------------------------------
Line 1,348 ⟶ 1,800:
put "Network Error:" && err
end if
end</
Executed in the "Message Window" (=Director's interactive Lingo console):
<
-- "<!doctype html>
...</
=={{header|LiveCode}}==
Without a callback handler the get URL method will block until complete
<
get URL "http://httpbin.org/html"
put it</
Non-blocking version
<
answer "Download Complete" with "Okay"
end myUrlDownloadFinished
Line 1,367 ⟶ 1,819:
command getWebResource
load URL "http://httpbin.org/html" with message "myUrlDownloadFinished"
end getWebResource</
=={{header|LSL}}==
To test it yourself; rez a box on the ground, and add the following as a New Script.
<
key kHttpRequestId;
default {
Line 1,391 ⟶ 1,843:
}
}
</syntaxhighlight>
Output:
<pre>Status=200
Line 1,416 ⟶ 1,868:
=={{header|Lua}}==
{{libheader|LuaSocket}}
<syntaxhighlight lang="lua">
local http = require("socket.http")
local url = require("socket.url")
local page = http.request('http://www.google.com/m/search?q=' .. url.escape("lua"))
print(page)
</syntaxhighlight>
=={{header|M2000 Interpreter}}==
We use Async read from Microsoft.XMLHTTP
So we use Threads (duration is in millisecond)
M2000 can use COM objects, using Declare, Method and With statements.
Using With statement we can make objects properties like ReadyState as variables
(some of them as read only)
<syntaxhighlight lang="m2000 interpreter">
Module CheckIt {
Declare xml "Microsoft.XMLHTTP"
const testUrl$ = "http://www.rosettacode.org"
With xml, "readyState" as ReadyState
Method xml "Open", "Get", testUrl$, True ' True means Async
Method xml "send"
\\ We set a thread to count time
k=0
Thread {
k++
} as TimeOut interval 100
\\ In main thread we can check ReadyState and Mouse button
Task.Main 100 {
Print ReadyState
If ReadyState=4 then exit
if k>20 then exit ' 20*100= 2 sec
if mouse then exit ' exit if mouse click
}
\\ So now we can read
if ReadyState=4 then {
With xml, "responseText" AS AA$
\\ break AA$ to lines
Document BB$=AA$
\\ using line breaks as CRLF
Report BB$
}
Declare xml Nothing
}
CheckIt
</syntaxhighlight>
=={{header|Maple}}==
In Maple 18 or later:
<syntaxhighlight lang="maple">
content := URL:-Get( "http://www.google.com/" );
</syntaxhighlight>
In Maple 17 or earlier:
<syntaxhighlight lang="maple">
content := HTTP:-Get( "http://www.google.com/" );
</syntaxhighlight>
=={{header|Mathematica}} / {{header|Wolfram Language}}==
<syntaxhighlight lang="mathematica">
Print[Import["http://www.google.com/webhp?complete=1&hl=en", "Source"]]
</syntaxhighlight>
=={{header|MATLAB}} / {{header|Octave}}==
Line 1,444 ⟶ 1,935:
In this example we initiate an HTTP request for a single random number from [http://www.random.org random.org]:
<syntaxhighlight lang="matlab">
>> random = urlread('http://www.random.org/integers/?num=1&min=1&max=100&col=1&base=10&format=plain&rnd=new')
Line 1,450 ⟶ 1,941:
61
</syntaxhighlight>
It is possible to make more complicated requests, specifically "GET" and "POST," which is explained in the [http://www.mathworks.com/help/matlab/ref/urlread.html documentation].
=={{header|Microsoft Small Basic}}==
<syntaxhighlight lang="smallbasic">TextWindow.WriteLine(Network.GetWebPageContents("http://rosettacode.org"))</syntaxhighlight>
=={{header|MIRC Scripting Language}}==
See [[HTTP/MIRC Scripting Language]]
=={{header|Nanoquery}}==
<syntaxhighlight lang="nanoquery">import http
import url
url = new(URL, "http://rosettacode.org/wiki/Rosetta_Code")
client = new(HTTPClient, url.getHost())
client.connect()
response = client.get(url.getFile())
println response.get("body")</syntaxhighlight>
=={{header|Nemerle}}==
<
using System.Console;
using System.Net;
Line 1,474 ⟶ 1,979:
myStream.Close()
}
}</
=={{header|NetRexx}}==
Line 1,480 ⟶ 1,985:
An implementation of the [[#Java|Java]] version shown above; demonstrating NetRexx's ability to exploit the rich Java SDK.
<
options replace format comments java crossref symbols binary
Line 1,496 ⟶ 2,001:
end
return</
=={{header|NewLisp}}==
<syntaxhighlight lang="newlisp">
(get-url "http://www.rosettacode.org")
</syntaxhighlight>
=={{header|Nim}}==
Compile example with command <code>nim c -d:ssl httpClient.nim</code>.
<syntaxhighlight lang="nim">import httpclient
var client = newHttpClient()
echo client.getContent "http://rosettacode.org"</syntaxhighlight>
=={{header|Objeck}}==
<
use Collection;
Line 1,520 ⟶ 2,026:
};
}
}</
=={{header|Objective-C}}==
<
int main (int argc, const char * argv[]) {
Line 1,539 ⟶ 2,045:
}
return 0;
}</
=={{header|OCaml}}==
<
let () =
let url = "http://www.rosettacode.org" in
Line 1,548 ⟶ 2,054:
print_endline page_content;
;;
</syntaxhighlight>
The source code of the function ''make_request'' is [[Web_Scraping/OCaml|here]].
=={{header|Ol}}==
{{libheader|libcurl}}
<syntaxhighlight lang="scheme">
(import (lib curl))
(define curl (make-curl))
(curl 'url "http://rosettacode.org/")
(curl 'perform)
</syntaxhighlight>
=={{header|ooRexx}}==
Got this from a friend. Needs bsf4oorexx from sourceforge.
<br>Note that rosettacode.org (as used by java and NetRexx) does not permit this access!
<
sc =.bsf~new("java.util.Scanner",url~openStream)
loop while sc~hasNext
say sc~nextLine
End
::requires BSF.CLS -- get Java camouflaging support</
{{out}}
massaged to avoid problems.
<pre><-!DOCTYPE HTML-
..
-/html-</pre>
=={{header|Oz}}==
When creating a file object, it is possible to specify an URL instead of a filename:
<syntaxhighlight lang="oz">
declare
fun {GetPage Url}
Line 1,580 ⟶ 2,097:
in
{System.showInfo {GetPage "http://www.rosettacode.org"}}
</syntaxhighlight>
{{libheader|OzHttpClient}}
If you need more fine-grained control of the request, you could use a custom library:
<syntaxhighlight lang="oz">
declare
[HTTPClient] = {Module.link ['x-ozlib://mesaros/net/HTTPClient.ozf']}
Line 1,603 ⟶ 2,120:
in
{System.showInfo {GetPage "http://www.rosettacode.org"}}
</syntaxhighlight>
=={{header|Pascal}}==
{{works with|Free Pascal}}
Using [http://wiki.freepascal.org/fphttpclient fphttpclient]
<syntaxhighlight lang="pascal">{$mode objfpc}{$H+}
uses fphttpclient;
var
s: string;
hc: tfphttpclient;
begin
hc := tfphttpclient.create(nil);
try
s := hc.get('http://www.example.com')
finally
hc.free
end;
writeln(s)
end.</syntaxhighlight>
{{works with|Free Pascal}} {{libheader|CThreads}} {{libheader|Classes}} {{libheader|httpsend}}
<syntaxhighlight lang="pascal">program http;
{$mode objfpc}{$H+}
Line 1,653 ⟶ 2,190:
Readln;
end.</
=={{header|Peloton}}==
English dialect, short form:
<
<@ SAYURLLIT>http://rosettacode.org/wiki/Main_Page</@>
</syntaxhighlight>
English dialect, padded variable-length form:
<
<# SAY URLSOURCE LITERAL>http://rosettacode.org/wiki/Main_Page</#>
</syntaxhighlight>
=={{header|Perl}}==
Line 1,675 ⟶ 2,212:
This sample is nearly identical to the LWP sample except that it uses HTTP::Tiny which was added to the core libraries in [[Perl/5.14]].
<
require 5.014; # check HTTP::Tiny part of core
use HTTP::Tiny;
print( HTTP::Tiny->new()->get( 'http://rosettacode.org')->{content} );</
===Library examples===
Line 1,688 ⟶ 2,225:
Classic LWP sample.
<
$ua->agent(undef) ; # cloudflare blocks default LWP agent
print( get("http://www.rosettacode.org") );</
or with more error-checking
<
use LWP::UserAgent;
Line 1,702 ⟶ 2,239:
$response->is_success or die "Failed to GET '$url': ", $response->status_line;
print $response->as_string</
=={{header|
{{libheader|
Note that curl_easy_get_file() is better suited to multi-megabyte downloads than curl_easy_perform_ex().
<!--<syntaxhighlight lang="phix">(notonline)-->
<span style="color: #008080;">include</span> <span style="color: #000000;">builtins<span style="color: #0000FF;">\<span style="color: #000000;">libcurl<span style="color: #0000FF;">.<span style="color: #000000;">e</span>
<span style="color: #7060A8;">curl_global_init<span style="color: #0000FF;">(<span style="color: #0000FF;">)</span>
<span style="color: #004080;">atom</span> <span style="color: #000000;">curl</span> <span style="color: #0000FF;">=</span> <span style="color: #7060A8;">curl_easy_init<span style="color: #0000FF;">(<span style="color: #0000FF;">)</span>
<span style="color: #7060A8;">curl_easy_setopt<span style="color: #0000FF;">(<span style="color: #000000;">curl<span style="color: #0000FF;">,</span> <span style="color: #000000;">CURLOPT_URL<span style="color: #0000FF;">,</span> <span style="color: #008000;">"http://rosettacode.org/robots.txt"<span style="color: #0000FF;">)</span>
<span style="color: #004080;">object</span> <span style="color: #000000;">res</span> <span style="color: #0000FF;">=</span> <span style="color: #7060A8;">curl_easy_perform_ex<span style="color: #0000FF;">(<span style="color: #000000;">curl<span style="color: #0000FF;">)</span>
<span style="color: #7060A8;">curl_easy_cleanup<span style="color: #0000FF;">(<span style="color: #000000;">curl<span style="color: #0000FF;">)</span>
<span style="color: #7060A8;">curl_global_cleanup<span style="color: #0000FF;">(<span style="color: #0000FF;">)</span>
<span style="color: #7060A8;">puts<span style="color: #0000FF;">(<span style="color: #000000;">1<span style="color: #0000FF;">,<span style="color: #000000;">res<span style="color: #0000FF;">)
<!--</syntaxhighlight>-->
{{out}}
<pre>
User-agent: *
Allow: /mw/images/
Allow: /mw/skins/
Allow: /mw/title.png
Allow: /mw/resources/
Disallow: /w/
Disallow: /mw/
Disallow: /wiki/Special:
</pre>
=={{header|PHP}}==
<
readfile("http://www.rosettacode.org");
</syntaxhighlight>
=={{header|PicoLisp}}==
<syntaxhighlight lang="picolisp">
(load "@lib/http.l")
(client "rosettacode.org" 80 NIL # Connect to rosettacode
(out NIL (echo)) ) # Echo to standard output
</syntaxhighlight>
=={{header|Pike}}==
<
write("%s",Protocols.HTTP.get_url_data("http://www.rosettacode.org"));
</syntaxhighlight>
=={{header|PowerShell}}==
<
Invoke-WebRequest 'http://www.rosettacode.org'
</syntaxhighlight>
<syntaxhighlight lang="powershell">
$wc = New-Object Net.WebClient
$wc.DownloadString('http://www.rosettacode.org')
</syntaxhighlight>
=={{header|Prolog}}==
Works with SWI-Prolog and library http/http_open. (Extract from the doc).
<syntaxhighlight lang="prolog">
:- use_module(library( http/http_open )).
Line 1,761 ⟶ 2,305:
copy_stream_data(In, user_output),
close(In).
</syntaxhighlight>
=={{header|PureBasic}}==
<syntaxhighlight lang="purebasic">
InitNetwork()
OpenConsole()
Line 1,782 ⟶ 2,326:
DeleteFile(filename$)
EndIf
</syntaxhighlight>
Another solution using general networking commands
<syntaxhighlight lang="purebasic">
InitNetwork()
OpenConsole()
Line 1,800 ⟶ 2,344:
; next line only to prevent console from closing on Windows
Input()
</syntaxhighlight>
Of course you could use wget too.
Line 1,808 ⟶ 2,352:
;Python 3:
Using the [http://docs.python.org/py3k/library/urllib.request.html urllib.request] module.
<
import urllib.request
print(urllib.request.urlopen("http://rosettacode.org").read())
</syntaxhighlight>
Using a more low-level [https://docs.python.org/3/library/http.client.html http.client] library.
<
from http.client import HTTPConnection
conn = HTTPConnection("example.com")
Line 1,822 ⟶ 2,366:
result = conn.getresponse()
r1 = result.read() # This retrieves the entire contents.
</syntaxhighlight>
;Python 2:
Using the [http://docs.python.org/library/urllib.html urllib] library.
<
import urllib
print urllib.urlopen("http://rosettacode.org").read()
</syntaxhighlight>
Using the [http://docs.python.org/library/urllib2.html urllib2] library.
<
import urllib2
print urllib2.urlopen("http://rosettacode.org").read()
</syntaxhighlight>
{{libheader|Requests}}
{{works with|Python|2.7, 3.4–3.7}}
<syntaxhighlight lang="python">
import requests
print(requests.get("http://rosettacode.org").text)
</syntaxhighlight>
=={{header|R}}==
Line 1,843 ⟶ 2,395:
First, retrieve the webpage.
<syntaxhighlight lang="r">
library(RCurl)
webpage <- getURL("http://rosettacode.org")
Line 1,854 ⟶ 2,406:
.opts=list(proxy="123.123.123.123", proxyusername="domain\\username", proxypassword="mypassword", proxyport=8080))
#Don't forget that backslashes in your username or password need to be escaped!
</syntaxhighlight>
Now parse the html code into a tree and print the html.
<syntaxhighlight lang="r">
library(XML)
pagetree <- htmlTreeParse(webpage )
pagetree$children$html
</syntaxhighlight>
=={{header|Racket}}==
<syntaxhighlight lang="racket">
#lang racket
(require net/url)
Line 1,871 ⟶ 2,423:
#:redirections 100)
(current-output-port))
</syntaxhighlight>
=={{header|Raku}}==
(formerly Perl 6)
{{libheader|LWP}}
Using LWP::Simple from [https://modules.raku.org/search/?q=LWP%3A%3ASimple the Raku ecosystem].
<syntaxhighlight lang="raku" line>use LWP::Simple;
print LWP::Simple.get("http://www.rosettacode.org");
</syntaxhighlight>
or, without LWP::Simple:
<syntaxhighlight lang="raku" line>my $socket = IO::Socket::INET.new(host => "www.rosettacode.org",
port => 80,);
$socket.print("GET / HTTP/1.0\r\n\r\n");
print $socket.recv();
$socket.close;
</syntaxhighlight>
=={{header|REALbasic}}==
REALBasic provides an HTTPSocket class for handling HTTP connections. The 'Get' method of the HTTPSocket is overloaded and can download data to a file or return data as a string, in both cases a timeout argument can be passed.
<syntaxhighlight lang="realbasic">
Dim sock As New HTTPSocket
Print(sock.Get("http://www.rosettacode.org", 10)) //set the timeout period to 10 seconds.
</syntaxhighlight>
=={{header|REBOL}}==
<syntaxhighlight lang="rebol">
print read http://rosettacode.org
</syntaxhighlight>
=={{header|REXX}}==
Line 1,889 ⟶ 2,460:
This script takes an URL as an argument and displays the content on the terminal. It uses the external program `curl` to perform both the acquisition of the data and the display.
<
/* GET2.RX - Display contents of an URL on the terminal. */
/* Usage: rexx get.rx http://rosettacode.org */
parse arg url .
'curl' url</
A simple change to the script will redirect the output to an internal variable for internal processing. (Our "internal processing" in this case is to display it.)
<
/* GET2.RX - Display contents of an URL on the terminal. */
/* Usage: rexx get2.rx http://rosettacode.org */
Line 1,904 ⟶ 2,475:
do i = 1 to stuff.0
say stuff.i
end</
Another simple change redirects the output to another external program like a shell pipe.
<
/* GET3.RX - Display contents of an URL on the terminal. */
/* Usage: rexx get3.rx http://rosettacode.org */
parse arg url .
address system 'curl' url with output fifo ''
address system 'more' with input fifo ''</
=={{header|Ring}}==
<syntaxhighlight lang="ring">
See download("http://rosettacode.org")
</syntaxhighlight>
=={{header|RLaB}}==
Line 1,940 ⟶ 2,516:
Yahoo [http://ichart.finance.yahoo.com/table.csv?s=PFE&a=00&b=4&c=1982&d=00&e=10&f=2010&g=d&ignore=.csv].
<syntaxhighlight lang="rlab">
// get cvs data from Yahoo for Pfeizer (PFE)
url="http://ichart.finance.yahoo.com/table.csv?s=PFE&a=00&b=4&c=1982&d=00&e=10&f=2010&g=d&ignore=.csv";
Line 1,951 ⟶ 2,527:
x = readm(url);
close (url);
</syntaxhighlight>
=={{header|Ruby}}==
The simple way loads the entire content into memory, then prints it.
<
require 'open-uri'
print open("http://rosettacode.org") {|f| f.read}
</syntaxhighlight>
If the content might be large, the better way uses FileUtils.copy_stream.
<
require 'fileutils'
require 'open-uri'
open("http://rosettacode.org/") {|f| FileUtils.copy_stream(f, $stdout)}
</syntaxhighlight>
=={{header|Run BASIC}}==
<
=={{header|Rust}}==
Cargo.toml
<
[dependencies]
hyper = "0.6"
</syntaxhighlight>
src/main.rs
<
//cargo-deps: hyper="0.6"
// The above line can be used with cargo-script which makes cargo's dependency handling more convenient for small programs
Line 2,000 ⟶ 2,572:
println!("{}", body);
}
</syntaxhighlight>
=={{header|Scala}}==
{{libheader|Scala}}
<
object HttpTest extends App {
Line 2,010 ⟶ 2,582:
Source.fromURL("http://www.rosettacode.org").getLines.foreach(println)
}</
=={{header|Scheme}}==
{{works with|Guile}}
<
; Use the regular expression module to parse the url (included with Guile)
(use-modules (ice-9 regex))
Line 2,042 ⟶ 2,614:
(do ((c (read-char s) (read-char s))) ((eof-object? c))
(display c)))
</syntaxhighlight>
{{works with|Chicken Scheme}}
Using the [http://api.call-cc.org/doc/http-client http-client] library, this is trivial.
<
(use http-client)
(print
(with-input-from-request "http://google.com/"
#f read-string))
</syntaxhighlight>
=={{header|Seed7}}==
Line 2,057 ⟶ 2,629:
which gets data specified by an URL using the HTTP protocol.
<
$ include "seed7_05.s7i";
include "gethttp.s7i";
Line 2,064 ⟶ 2,636:
begin
writeln(getHttp("www.rosettacode.org"));
end func;</
=={{header|SenseTalk}}==
<syntaxhighlight lang="sensetalk">put url "http://www.rosettacode.org"</syntaxhighlight>
=={{header|Sidef}}==
Sidef can load and use Perl modules:
<syntaxhighlight lang
func get(url) {
static ua = %O<HTTP::Tiny>.new(agent => 'Mozilla/5.0')
var resp = ua.get(url)
if (resp{:success}) {
}
}
=={{header|Smalltalk}}==
{{works with|Pharo}}
<syntaxhighlight lang="smalltalk">
Transcript show: 'http://rosettacode.org' asUrl retrieveContents contentStream.
</syntaxhighlight>
=={{header|SNOBOL4}}==
{{works with|Macro SNOBOL4 in C}}
<
tcp.open(.conn,'www.rosettacode.org','http') :s(cont1)
terminal = "cannot open" :(end)
Line 2,091 ⟶ 2,671:
tcp.close(.conn)
end
</syntaxhighlight>
=={{header|Swift}}==
<
let request = NSURLRequest(URL: NSURL(string: "http://rosettacode.org/")!)
Line 2,113 ⟶ 2,688:
}
CFRunLoopRun() // dispatch</
=={{header|Tcl}}==
Note that the <code>http</code> package is distributed as part of Tcl.
<
package require http
set request [http::geturl "http://www.rosettacode.org"]
puts [http::data $request]
http::cleanup $request</
=={{header|TSE SAL}}==
<syntaxhighlight lang="tse sal">
DLL "<urlmon.dll>"
Line 2,150 ⟶ 2,726:
END
</syntaxhighlight>
=={{header|TUSCRIPT}}==
<
$$ MODE TUSCRIPT
SET DATEN = REQUEST ("http://www.rosettacode.org")
*{daten}
</syntaxhighlight>
=={{header|UNIX Shell}}==
<
<
<
<
{{works with|BSD}}
<
=={{header|VBScript}}==
Line 2,175 ⟶ 2,751:
Based on code at [http://itknowledgeexchange.techtarget.com/vbscript-systems-administrator/how-to-retrieve-html-web-pages-with-vbscript-via-the-microsoftxmlhttp-object/ How to retrieve HTML web pages with VBScript via the Microsoft.XmlHttp object]
<syntaxhighlight lang="vb">
Option Explicit
Line 2,193 ⟶ 2,769:
Set oHTTP = Nothing
</syntaxhighlight>
=={{header|Visual Basic}}==
{{Libheader|Microsoft.WinHttp}}
{{works with|Visual Basic|5}}
{{works with|Visual Basic|6}}
{{works with|VBA|Access 97}}
{{works with|VBA|6.5}}
{{works with|VBA|7.1}}
<syntaxhighlight lang="vb">Sub Main()
Dim HttpReq As WinHttp.WinHttpRequest
' in the "references" dialog of the IDE, check
' "Microsoft WinHTTP Services, version 5.1" (winhttp.dll)
Const HTTPREQUEST_PROXYSETTING_PROXY As Long = 2
#Const USE_PROXY = 1
Set HttpReq = New WinHttp.WinHttpRequest
HttpReq.Open "GET", "http://rosettacode.org/robots.txt"
#If USE_PROXY Then
HttpReq.SetProxy HTTPREQUEST_PROXYSETTING_PROXY, "my_proxy:80"
#End If
HttpReq.SetTimeouts 1000, 1000, 1000, 1000
HttpReq.Send
Debug.Print HttpReq.ResponseText
End Sub</syntaxhighlight>
=={{header|Visual Basic .NET}}==
<
Imports System.Net
Line 2,202 ⟶ 2,801:
Dim content As String = client.DownloadString("http://www.google.com")
Console.WriteLine(content)
</syntaxhighlight>
=={{header|V (Vlang)}}==
<syntaxhighlight lang="Vlang">
import net.http
fn main() {
resp := http.get("http://rosettacode.org/robots.txt") or {println(err) exit(-1)}
println(resp.body.str())
}
</syntaxhighlight>
=={{header|Wren}}==
{{trans|C}}
{{libheader|libcurl}}
An embedded program so we can ask the C host to communicate with libcurl for us.
<syntaxhighlight lang="wren">/* HTTP.wren */
var CURLOPT_URL = 10002
var CURLOPT_FOLLOWLOCATION = 52
var CURLOPT_ERRORBUFFER = 10010
foreign class Curl {
construct easyInit() {}
foreign easySetOpt(opt, param)
foreign easyPerform()
foreign easyCleanup()
}
var curl = Curl.easyInit()
if (curl == 0) {
System.print("Error initializing cURL.")
return
}
curl.easySetOpt(CURLOPT_URL, "http://www.rosettacode.org/")
curl.easySetOpt(CURLOPT_FOLLOWLOCATION, 1)
curl.easySetOpt(CURLOPT_ERRORBUFFER, 0) // buffer to be supplied by C
var status = curl.easyPerform()
if (status != 0) {
System.print("Failed to perform task.")
return
}
curl.easyCleanup()</syntaxhighlight>
<br>
We now embed this in the following C program, compile and run it.
<syntaxhighlight lang="c">/* gcc HTTP.c -o HTTP -lcurl -lwren -lm */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <curl/curl.h>
#include "wren.h"
/* C <=> Wren interface functions */
void C_curlAllocate(WrenVM* vm) {
CURL** pcurl = (CURL**)wrenSetSlotNewForeign(vm, 0, 0, sizeof(CURL*));
*pcurl = curl_easy_init();
}
void C_easyPerform(WrenVM* vm) {
CURL* curl = *(CURL**)wrenGetSlotForeign(vm, 0);
CURLcode cc = curl_easy_perform(curl);
wrenSetSlotDouble(vm, 0, (double)cc);
}
void C_easyCleanup(WrenVM* vm) {
CURL* curl = *(CURL**)wrenGetSlotForeign(vm, 0);
curl_easy_cleanup(curl);
}
void C_easySetOpt(WrenVM* vm) {
CURL* curl = *(CURL**)wrenGetSlotForeign(vm, 0);
CURLoption opt = (CURLoption)wrenGetSlotDouble(vm, 1);
if (opt < 10000) {
long lparam = (long)wrenGetSlotDouble(vm, 2);
curl_easy_setopt(curl, opt, lparam);
} else {
if (opt == CURLOPT_URL) {
const char *url = wrenGetSlotString(vm, 2);
curl_easy_setopt(curl, opt, url);
} else if (opt == CURLOPT_ERRORBUFFER) {
char buffer[CURL_ERROR_SIZE];
curl_easy_setopt(curl, opt, buffer);
}
}
}
WrenForeignClassMethods bindForeignClass(WrenVM* vm, const char* module, const char* className) {
WrenForeignClassMethods methods;
methods.allocate = NULL;
methods.finalize = NULL;
if (strcmp(module, "main") == 0) {
if (strcmp(className, "Curl") == 0) {
methods.allocate = C_curlAllocate;
}
}
return methods;
}
WrenForeignMethodFn bindForeignMethod(
WrenVM* vm,
const char* module,
const char* className,
bool isStatic,
const char* signature) {
if (strcmp(module, "main") == 0) {
if (strcmp(className, "Curl") == 0) {
if (!isStatic && strcmp(signature, "easySetOpt(_,_)") == 0) return C_easySetOpt;
if (!isStatic && strcmp(signature, "easyPerform()") == 0) return C_easyPerform;
if (!isStatic && strcmp(signature, "easyCleanup()") == 0) return C_easyCleanup;
}
}
return NULL;
}
static void writeFn(WrenVM* vm, const char* text) {
printf("%s", text);
}
void errorFn(WrenVM* vm, WrenErrorType errorType, const char* module, const int line, const char* msg) {
switch (errorType) {
case WREN_ERROR_COMPILE:
printf("[%s line %d] [Error] %s\n", module, line, msg);
break;
case WREN_ERROR_STACK_TRACE:
printf("[%s line %d] in %s\n", module, line, msg);
break;
case WREN_ERROR_RUNTIME:
printf("[Runtime Error] %s\n", msg);
break;
}
}
char *readFile(const char *fileName) {
FILE *f = fopen(fileName, "r");
fseek(f, 0, SEEK_END);
long fsize = ftell(f);
rewind(f);
char *script = malloc(fsize + 1);
fread(script, 1, fsize, f);
fclose(f);
script[fsize] = 0;
return script;
}
int main(int argc, char **argv) {
WrenConfiguration config;
wrenInitConfiguration(&config);
config.writeFn = &writeFn;
config.errorFn = &errorFn;
config.bindForeignClassFn = &bindForeignClass;
config.bindForeignMethodFn = &bindForeignMethod;
WrenVM* vm = wrenNewVM(&config);
const char* module = "main";
const char* fileName = "HTTP.wren";
char *script = readFile(fileName);
WrenInterpretResult result = wrenInterpret(vm, module, script);
switch (result) {
case WREN_RESULT_COMPILE_ERROR:
printf("Compile Error!\n");
break;
case WREN_RESULT_RUNTIME_ERROR:
printf("Runtime Error!\n");
break;
case WREN_RESULT_SUCCESS:
break;
}
wrenFreeVM(vm);
free(script);
return 0;
}</syntaxhighlight>
=={{header|X86-64 Assembly}}==
===UASM 5.52===
The same as the [[Sockets]] example, Just with a read method added...
<syntaxhighlight lang="asm">
option casemap:none
option literals:on
ifndef __SOCKET_CLASS__
__SOCKET_CLASS__ equ 1
if @Platform eq windows64
WSADATA struct
wVersion dw ?
wHighVersion dw ?
iMaxSockets dw ?
iMaxUdpDg dw ?
szDescription db 256 dup (?)
szSystemStatus db 128 dup (?)
lpVendorInfo dq ?
WSADATA ends
option dllimport:<kernel32>
ExitProcess proto :word
HeapAlloc proto :qword, :dword, :qword
HeapFree proto :qword, :dword, :qword
GetProcessHeap proto
option dllimport:<ws2_32>
WSAStartup proto :word, :qword
WSACleanup proto :qword
closesocket proto :dword
option dllimport:none
exit equ ExitProcess
close equ closesocket
elseif @Platform eq linux64
malloc proto SYSTEMV :qword
free proto SYSTEMV :qword
close proto SYSTEMV :dword
exit proto SYSTEMV :dword
endif
memset proto :qword, :dword, :dword
printf proto :qword, :vararg
strlen proto :qword
getaddrinfo proto :qword, :qword, :qword, :qword
gai_strerror proto :dword
send proto :dword, :qword, :qword, :dword
recv proto :dword, :qword, :qword, :dword
socket proto :dword, :dword, :dword
connect proto :dword, :qword, :dword
freeaddrinfo proto :qword
CLASS socket_class
CMETHOD conn
CMETHOD write
CMETHOD read
ENDMETHODS
if @Platform eq windows64
wsa WSADATA <?>
endif
sock dd 0
pai dq 0
hostname dq ?
port dq ?
ENDCLASS
METHOD socket_class, Init, <VOIDARG>, <>, h:qword, p:qword
mov rbx, thisPtr
assume rbx:ptr socket_class
mov rax, h
mov [rbx].hostname, rax
mov rax, p
mov [rbx].port, rax
mov rax, rbx
assume rbx:nothing
ret
ENDMETHOD
METHOD socket_class, conn, <dword>, <>
local ht:qword
mov rbx, thisPtr
assume rbx:ptr socket_class
invoke printf, CSTR("--> Attempting connection to %s on %s",10), [rbx].hostname ,[rbx].port
if @Platform eq windows64
invoke WSAStartup, 202h, addr [rbx].wsa
endif
invoke memset, ht, 0, 0x30 ;; sizeof(struct addrinfo)
mov rax, ht
mov dword ptr [rax], 0 ;; ai_flags
mov dword ptr [rax+4], AF_INET
mov dword ptr [rax+8], SOCK_STREAM
invoke getaddrinfo, [rbx].hostname, [rbx].port, ht, addr [rbx].pai
.if rax != 0
invoke gai_strerror, eax
invoke printf, CSTR("--> Gai_strerror returned: %s",10), rax
mov rax, -1
jmp _exit
.endif
mov rax, [rbx].pai
mov edx, dword ptr [rax + 0XC] ;; pai.ai_protocol
mov ecx, dword ptr [rax + 8] ;; pai.ai_socktype
mov eax, dword ptr [rax + 4] ;; pai.ai_family
invoke socket, eax, ecx, edx
.if rax == -1
mov rax, -1
jmp _exit
.endif
mov [rbx].sock, eax
invoke printf, CSTR("--> Socket created as: %d",10), [rbx].sock
mov rax, [rbx].pai
mov edx, dword ptr [rax + 0x10] ;; pai.ai_addrlen
mov rcx, qword ptr [rax + 0x18] ;; pai.ai_addr
invoke connect, [rbx].sock, rcx, edx
.if rax == -1
invoke printf, CSTR("--> connect failed.. %i",10), rax
mov rax, -1
jmp _exit
.endif
mov rax, 0
_exit:
assume rbx:nothing
ret
ENDMETHOD
METHOD socket_class, write, <dword>, <>, b:qword
local tmp:qword
mov rbx, thisPtr
assume rbx:ptr socket_class
mov rax, b
mov tmp, rax
invoke strlen, tmp
mov rdx, rax
invoke send, [rbx].sock, tmp, rdx, 0
.if eax == -1
invoke printf, CSTR("--> Error in send..%d",10), rax
ret
.endif
assume rbx:nothing
ret
ENDMETHOD
METHOD socket_class, read, <VOIDARG>, <>, b:qword
local tmp:qword
mov rbx, thisPtr
assume rbx:ptr socket_class
mov rax, b
mov tmp, rax
invoke recv, [rbx].sock, tmp,MAX_READ_BYTES, 0
push rax
mov rax, tmp
mov b, rax
pop rax
invoke printf, CSTR("--> recv called, got %d bytes..",10), rax
assume rbx:nothing
ret
ENDMETHOD
METHOD socket_class, Destroy, <VOIDARG>, <>
mov rbx, thisPtr
assume rbx:ptr socket_class
invoke close, [rbx].sock
if @Platform eq windows64
invoke WSACleanup, addr [rbx].wsa
endif
.if [rbx].pai != 0
invoke freeaddrinfo, [rbx].pai
.endif
assume rbx:nothing
ret
ENDMETHOD
endif ;; __SOCKET_CLASS__
MAX_READ_BYTES equ 4023
.code
main proc
local lpSocket:ptr socket_class
local buffer:qword
mov lpSocket, _NEW(socket_class, CSTR("www.google.com"), CSTR("80"))
lpSocket->conn()
.if rax == -1
invoke exit, 0
ret
.endif
invoke printf, CSTR("-> Connected, sending data.",10)
lpSocket->write(CSTR("GET / HTTP 1.0",13,10,"Accept: text/html",13,10,13,10))
MEMALLOC(MAX_READ_BYTES)
mov buffer, rax
lpSocket->read(buffer)
invoke printf, CSTR("%s"), buffer
MEMFREE(buffer)
_DELETE(lpSocket)
invoke exit, 0
ret
main endp
end
</syntaxhighlight>
=={{header|zkl}}==
File htmlGet.zkl. This uses HTTP/1.0 Protocol to avoid chunked data. Or use cURL (see https example).
<
host := url;
Line 2,219 ⟶ 3,200:
server.write(get);
data := server.read(True);
println(data.text);</
zkl htmlGet.zkl rosettacode.org/wiki/HTTP
{{out}}
Line 2,253 ⟶ 3,234:
...
</pre>
=={{header|Zoea}}==
<syntaxhighlight lang="zoea">
program: http
input: 'https://zoea.co.uk/examples/test.txt'
output: 'hello from zoea'
</syntaxhighlight>
=={{header|Zoea Visual}}==
[http://zoea.co.uk/examples/zv-rc/Http.png HTTP]
=={{header|Zsh}}==
<
zmodload zsh/net/tcp
ztcp example.com 80
Line 2,262 ⟶ 3,253:
while read -u $fd -r -e -t 1; do; :; done
ztcp -c $fd
</syntaxhighlight>
{{omit from|Applesoft BASIC|No TCP/IP network support on Apple II}}
{{omit from|Brainf***}}
{{omit from|Commodore BASIC|Does not have network access}}
{{omit from|EasyLang|Has no internet functions}}
{{omit from|Inform 7|Does not have network access.}}
{{omit from|Integer BASIC|No TCP/IP network support on Apple II}}
Line 2,277 ⟶ 3,270:
{{omit from|PostScript}}
{{omit from|Retro|Does not have network access.}}
{{omit from|SQL PL|Does not have network access}}
{{omit from|TI-83 BASIC|Does not have network access.}}
{{omit from|TI-89 BASIC|Does not have network access.}}
Line 2,282 ⟶ 3,276:
{{omit from|Yorick|Does not have network access.}}
{{omit from|ZX Spectrum Basic|Does not have network access.}}
|