Placeholder Image

Subtitles section Play video

  • [BELL RINGING]

  • Welcome back.

  • I don't know what you did since the last video,

  • but I went and got a haircut.

  • Thank you.

  • In this video, I am going to do something important,

  • a key feature here.

  • What I want to do is take data from the client, the latitude

  • and longitude, and send it to the server

  • and have the server receive it.

  • Ultimately, the point of this is for the server

  • to eventually save that to a database.

  • But I'm not there yet.

  • I just want to say, the client executes its own client side

  • JavaScript, gets the latitude and longitude,

  • and sends that data to the server and the server

  • can just console log it.

  • I'm going to need to look at three things

  • in order to do this, I'm going to need

  • to look at a concept known as a routing,

  • how do I set up a route in express.

  • This is the place, the end point for the API, the address

  • at which I will send the data to and later also make

  • a request to receive some data.

  • I need to look at adding JSON parsing to express.

  • I need the route when it receives

  • data to understand that data as JSON

  • and make it readable in my code.

  • And then I also need to look at adapting the fetch function

  • to specify a POST request, a request that is posting data

  • or sending data to the server.

  • Let's start with the route.

  • So I want to set up a route on my server.

  • So the way that I do that is by specifying

  • this particular route, will either be a Get or a POST.

  • In this case I expect a POST request,

  • so I am going to go and say app.post.

  • Now, once I have a post, I want to specify both the address

  • where I want to receive that POST, as well as a callback

  • function where I'm going to look at the information coming in

  • and send a response back.

  • So let's set up that address, let's

  • set up the endpoint for this particular route.

  • Where I want to receive the post.

  • And I could call it anything I want, like Unicorn, Cupcake,

  • Rainbow.

  • Let's call it Rainbow.

  • All right, I'll give it a name that's maybe more appropriate.

  • I'm going to call it API.

  • API because what I'm really doing here

  • is setting up an application programming interface.

  • This is my API for clients to send data to me.

  • Next, I'm going to set up a callback, request response,

  • and I'm using the ES6, JavaScript ES6 arrow syntax.

  • Just sort of a nice, clean way of putting this in here.

  • So the function is here and it has two arguments, request

  • and response.

  • The request variable hold everything

  • that's contained within that request, all the data that's

  • being sent, any information I need

  • to know about that particular client that's

  • sending the information.

  • The response is a variable that I can use to send things back

  • to the client.

  • So I'm going to need ultimately to do stuff there,

  • but for right now, I'm just going

  • to say console.log request, and I'm just

  • going to leave it like that because let's at least see

  • if we can get this working and see if we can see

  • something console log there.

  • The next step is to have my client send something

  • to this particular endpoint with a post.

  • I can now move over to the client code

  • and setup the post itself using Fetch.

  • So I want to fetch my post over to slash API endpoint.

  • So the client code, remember, this

  • is confusing, server and index.js, client

  • and index.html.

  • I'm going to move over here.

  • This, what I'll do is I'll choose

  • to send this latitude and longitude as soon as I've

  • received it.

  • This is what I did in the previous video.

  • And so now, what I can do is I'll setup--

  • I'm just going to make up an object called Data,

  • and what I want to send is the latitude and longitude

  • inside of an object.

  • So that's what I want to send.

  • So you might think all I need to do if I were just

  • doing a regular Fetch, right?

  • I just wanted to fetch something, that's

  • a Get, regular Get request like I did in previous videos,

  • I would then just say this.

  • Hey, fetch me the stuff from slash API,

  • and I might actually do that a little later when I just

  • do a Get request and get the data that's in the database.

  • But right now, what I want to do is send a POST.

  • In order to send a POST, I need a second argument here,

  • which is just a JavaScript object.

  • I'm going to call it options, and that way I

  • can set it up separately as a variable and kind

  • of examine it more closely.

  • The first property that I need to put in options

  • is the method that I'm using.

  • And that method is a POST.

  • Now, there's a lot of information

  • that you can put here under Options.

  • And if you want to look at all the possibilities,

  • I refer you back to the MDN web docs.

  • There's a nice page here about fetch

  • and we can kind of see all the stuff.

  • OK, what mode and cash and credentials,

  • but really what I need, what I want, the key thing that I want

  • is body.

  • So the body of the POST request is where I'm

  • packaging up all of my data.

  • And you can see here, even though there

  • are different ways to send the data, what I want to do

  • is send it as a string text.

  • I want to stringify, take the JavaScript object data

  • and make it into a JSON string.

  • So I want exactly this right here.

  • And there's one other piece that's important.

  • I am specifically sending data in JSON format.

  • So it's useful to specify that in something called a header.

  • A header is something that can be packaged along with any POST

  • or Get request that's moving between client and server,

  • and it's a way of adding some additional meta information.

  • You can read more about this also on the Mozilla docs.

  • Headers have a name, a colon, and a value.

  • And so the one that I want to use here,

  • I can actually just go and grab it

  • from here, which is this content type application JSON.

  • I'm going to grab this and I'm also

  • going to put this here in my code.

  • So even though there's more that I could put,

  • I the basic pieces that I need are,

  • hey, I want this data to get sent as JSON.

  • I want to tell you that it's going to be JSON

  • and I want to post it to the API.

  • So now we're good, right?

  • So I get the location data, I put it

  • into a JavaScript object, I package it as a POST,

  • and I send it to my endpoint.

  • And in the server, I receive a console log.

  • Let's see what happens.

  • So I'm going to say node index.js to run the server.

  • I'm going to go back to the browser,

  • I'm going to refresh my page, I probably

  • should put some console logging in the client to see--

  • but presumably now, it's sensing the server.

  • I don't see an error here, I go back to the server--

  • whoa, so this is good news.

  • It console-logged something.

  • Oh, as you might have noticed, there's a ton of information

  • as I scroll through this, crazily.

  • While there might be points at which I

  • need to examine certain aspects of all of the metadata that's

  • part of the request, all I really want to look at

  • is the body.

  • So let me now say console log request.body.

  • Now, one thing I should mention, by the way,

  • is notice how I have to re-run the server

  • every single time I change it, there is a utility

  • that I could use called Node Mon or node monitor,

  • and I could install it as a global node module.

  • [MUSIC PLAYING]

  • And if I choose to use it, I can say now, Node Mon for node

  • monitor index.js.

  • And anytime I change the code it's going to rewrite the--

  • sorry, anytime I change the code,

  • it's going to rerun the server.

  • So, for example, I'm going to go here

  • and say, console.log, I got a request.

  • And over here, you'll notice it restarted the server.

  • Sometimes you could run into trouble with this

  • if you're doing a lot of things at once

  • and I often prefer to manually stop and start the server.

  • But for right now, this might be useful.

  • So let me leave that there for right now.

  • Then I'm going to go over here and hit refresh.

  • And presumably it sent the data--

  • oh, it must have sent the data.

  • Presumably it sent the data.

  • I'll go back to the server.

  • I got a request.

  • Undefined, undefined.

  • Why is it undefined?

  • I forgot one of the steps that I told you about.

  • So I did two of them, right?

  • I set up my route called API to receive the request.

  • I also modified the fetch function

  • to send data as a POST.

  • What I did not do was add to my server

  • the ability to parse any incoming data as JSON.

  • The way to do that is with the express function express.json.

  • So, similarly to how I used express.static to say,

  • I want to host--

  • I want this server to host static files,

  • I'm going to say express.json because I

  • want this server to be able to understand

  • incoming data as JSON.

  • So In the code I want to do just like I did up

  • here, app.use express.static, I'm going

  • to say app.use express.json.

  • And then I can actually put some options in here

  • to control or limit what is possible in terms

  • of receiving data.

  • So all of that is documented here on the Express website.

  • Let's add just as an example this limit.

  • So Limit allows me to specify the maximum size of anybody

  • that's coming in.

  • So I'll say a limit.

  • Let's just say one megabyte as a kind of starting point.

  • So this protects against flooding my server

  • with huge amounts of data, potentially.

  • There's more to protecting your server than just that,

  • but we're seeing an inkling of this here.

  • All right.

  • So now we can see Node Mon has restarted

  • my server a bunch of times and I should

  • be able to go back to the webpage and hit Refresh.

  • And it's going to get the latitude and longitude,

  • and now I should see the server--

  • ha-ha, I got a request and I got the latitude and longitude.

  • So the server has successfully received the data.

  • This is what I wanted to do in this video.

  • So in a way, I'm done.

  • Oh, that's exciting.

  • What I've actually done here is pretty

  • terrible in that it is required that you complete a request.

  • So if a Get request or a POST request

  • is coming into the server, I need

  • to do something to complete it.

  • The nicest thing to do if I'm trying to be polite here,

  • which it's good for your server to be polite and send

  • a response back.

  • But at a minimum, I can just say response.end.

  • So this is required to do something.

  • What I think that I would like to do which makes more sense

  • is say response.json, which is a function that will send data.

  • I can also say response.send for just a short message

  • as a string, but I want to send maybe

  • an object back with some data in it.

  • So I'm going to do response.json,

  • and then I would say--

  • I could say like status.

  • I'm just making this up.

  • Success.

  • And then maybe I'll just repeat back what was said to me.

  • This is the therapy server, it listens and then

  • it just repeats it back to you.

  • So I'll say latitude, lat, longitude, lon.

  • So this is what I want to send back now as JavaScript.

  • OK.

  • So then in the client I need to do something to receive this.

  • So if I go back to index.html, what I have here

  • calling the fetch function is where I'm sending the data,

  • and Fetch returns a promise.

  • So I can just say dot then, and then handle the response.

  • Response console.log.response.

  • All right.

  • So let's take a look at this in the browser now.

  • I'm going to hit refresh.

  • It's retrieving my latitude and longitude,

  • it's going to send this to the server,

  • and then here we are, the response.

  • Oh, boy.

  • Look at this.

  • Lat is not defined.

  • Let's look at my code back on the server-- oh, yes.

  • These aren't a thing.

  • Remember, everything is in request.body.

  • So what I could do is say data equals--

  • I could put this in another variable.

  • And then I could just say data dot--

  • I could just say request.body.lat, data.lon.

  • OK.

  • There we go.

  • Let's try this again.

  • So the server should be restarting now

  • any time I make changes because I'm running Node Mon,

  • then I could just go back to the client and hit Refresh.

  • And there is, the response.

  • Now, this isn't what I was looking for.

  • And if you recall from when I first looked at the Fetch

  • function in this whole series, when Response comes back

  • after a Fetch call, it comes in as a data stream.

  • So it's up to you to specify how you want to read that, is it

  • text, is it a blob, is it json, and I

  • want to read this as JSON.

  • So I've got a handle that in the client.

  • And I could use another dot then,

  • but it might be nice to make this an async function, right?

  • This callback inside of get current position can actually

  • be an async function with the async keyword,

  • and then I can use--

  • wait, so I'm going to say const response equals await Fetch API

  • options, then const json.

  • I'll just maybe call it data.

  • There's a wait response.json, and then console log that data.

  • OK.

  • Now I didn't change anything in the server,

  • even if I did, Node Mon going to rerun it for me.

  • Now I should be able to refresh here.

  • Data has already been declared.

  • I'm reusing-- I already use data up here,

  • so let's just call this json.

  • One of the nice things about using or let

  • is it's going to enforce these kind of things to not by action

  • use the same variable.

  • And there it is.

  • Status success and latitude and longitude.

  • [BELL RINGING]

  • We have completed this feature to review.

  • We have now a server that hosts a static file.

  • So when I go and load the server into my browser,

  • I see index.html.

  • The JavaScript HTML locates the latitude and longitude,

  • sends that with a POST to the server, the server receives it,

  • console logs it out, and sends it back saying, I got it.

  • That handshake is complete, the data is exchanged.

  • Usually when I finish these videos

  • I like to give you a little exercise to do, so here's one.

  • The goal, what I'm going to do with the next video

  • is actually save the latitude and longitude

  • along with a timestamp to a database

  • so that I can keep this history of all of my latitude

  • and longitudes over time.

  • Two steps along the way to using a database is, number one,

  • just make a variable, a variable like an array.

  • Every time you get that latitude and longitude

  • save that latitude and longitude into an array.

  • That is persistence.

  • Of course, once you quit the server and restart the server,

  • it's lost.

  • So another thing you could try to do,

  • and this requires some detective work,

  • is look up the Node file system package.

  • Maybe you could use the node file system package

  • to save all of the stuff in that array to a text file.

  • And you can always load that text file, maybe it's JSON

  • format, maybe it's plain text, maybe it's even CSV.

  • Also, while you're doing this, whether you're

  • saving the latitude longitude to an array or a text file,

  • you might want to add a button to your HTML page

  • so that every time you click that button that's

  • when you send the latitude and longitude to the server itself.

  • So this is something that you can really start with,

  • and I will actually implement this and have two examples that

  • show it just storing it an array and then saving it

  • to a local JSON file.

  • But what I'm going to come back to in the next video

  • is a bit more direct.

  • I'm going to use a database node package called NeDB to actually

  • save to a database, and I'll talk about what a database is

  • and what some of the advantages are in the next video.

  • So see you there.

  • [BELL RINGING]

  • [MUSIC PLAYING]

[BELL RINGING]

Subtitles and vocabulary

Click the word to look it up Click the word to find further inforamtion about it