Lets say..
if i hit google with https://www.google.com it will create a session, for the responce it
will create url with session tokn like..
https://www.google.co.in/?gfe_rd=cr&ei=oFBjVJSvLqnM8gft5YDwAQ&gws_rd=ssl.
My question is
am connecting to google with the code:
URL url = new URL(test);
URLConnection conn = url.openConnection();
this will connect to google.
for this google creates a session.
then how would i get a session token back to my code?
You can get the session token from the cookie of the browser. You can, find the cookie settings->advanced settings->privacy->content settings->allcookie and site data then search www.google.com and select sid and copy the content .
You can extract any cookie, not only the one containing the session with the following approach:
Since a server may set multiple cookies in a single request, we will need to loop through the response headers, looking for all headers named "Set-Cookie".
String headerName=null;
for (int i=1; (headerName = uc.getHeaderFieldKey(i))!=null; i++) {
if (headerName.equals("Set-Cookie")) {
String cookie = urlConn.getHeaderField(i);
The string returned by the getHeaderField(int index) method is a series of name=value separated by semi-colons (;). The first name/value pairing is actual data string we are interested in (i.e. "sessionId=0949eeee22222rtg"), the subsequent name/value pairings are meta-information that we would use to manage the storage of the cookie (when it expires, etc.).
cookie = cookie.substring(0, cookie.indexOf(";"));
String cookieName = cookie.substring(0, cookie.indexOf("="));
String cookieValue = cookie.substring(cookie.indexOf("=") + 1, cookie.length());
This is basically it. We now have the cookie name (cookieName) and the cookie value (cookieValue).
the above explanation was based on example provided in http://www.hccp.org/java-net-cookie-how-to.html#retrieving_cookies
A more sophisticated approach is to use CookieAccessor class:
public void getCookieUsingCookieHandler() {
try {
// Instantiate CookieManager;
// make sure to set CookiePolicy
CookieManager manager = new CookieManager();
manager.setCookiePolicy(CookiePolicy.ACCEPT_ALL);
CookieHandler.setDefault(manager);
// get content from URLConnection;
// cookies are set by web site
URL url = new URL("http://host.example.com");
URLConnection connection = url.openConnection();
connection.getContent();
// get cookies from underlying
// CookieStore
CookieStore cookieJar = manager.getCookieStore();
List <HttpCookie> cookies =
cookieJar.getCookies();
for (HttpCookie cookie: cookies) {
System.out.println("CookieHandler retrieved cookie: " + cookie);
}
} catch(Exception e) {
System.out.println("Unable to get cookie using CookieHandler");
e.printStackTrace();
}
}
In any approach you follow you need to know what is the name of the cookie holding the session id, so that you can get the value from it. E.g a java web application usually creates a cookie with name "JSESSIOINID"
Related
I'm looking for the posts count of an hashtag using the "?__a=1" Instagram open API.
I'm using Java. I make a GET request to the endpoint "https://www.instagram.com/explore/tags/cachorro/?__a=1", store the response to a JSONObject and get the posts count in this way:
object.getJSONObject("graphql").getJSONObject("hashtag").getJSONObject("edge_hashtag_to_media").getInt("count")
When I execute the code on my development PC, I get the right value:
{
"count": 8546301,
"page_info": {
"has_next_page": true,
"end_cursor": "QVFCVHpDLTR4RHNUMjVPN1FOQk03QXpKWWRwYnk3ZjZJek5uOEdfczNYcWJiOWtSU3VIbEtuUzMwN01KSDYwaGs1eWJ0WUVrSWVjR3RMeEFfTTB1S1NRQw=="
}...
When the code is executed on my VPS server, I get an empty value:
{"count":0,"page_info":{"has_next_page":false,"end_cursor":null},"edges":[]}
I'm using HttpURLConnection with all the cookies needed by Instagram:
HttpURLConnection con = (HttpURLConnection) url.openConnection();
InstagramCookieBuilder cookieBuilder = new InstagramCookieBuilder();
InstagramCookie cookie = cookieBuilder.igDid("HIDDEN")
.mid("HIDDEN")
.shbid("HIDDEN")
.shbts("HIDDEN")
.sessionId("HIDDEN")
.rur("HIDDEN")
.csrfToken("HIDDEN")
.dsUserId("HIDDEN")
.urlGen("\"{\"VPS_IP_ADDRESS\": HIDDEN\HIDDEN\"VPS_MAC_ADDRESS\": HIDDEN}:HIDDEN\"")
.build();
String cookieString = cookie.toString();
con.setRequestProperty("Cookie", cookieString);
What is wrong?
I have a situation where i need to set cookie in JSP and i need to get those cookie in normal java class.
The JSP:
CookieManager manager = new CookieManager();
CookieHandler.setDefault(manager);
CookieStore cookieJar = manager.getCookieStore();
// create cookie
HttpCookie cookie = new HttpCookie("UserName", "John Doe");
// add cookie to CookieStore for a
// particular URL
URL url = new URL("http://localhost:8080");
url.openConnection().connect();
cookieJar.add(url.toURI(), cookie);
System.out.println("Added cookie using cookie handler");
%>
Below is the Java class [not a servlet class] and this class is running in the server and this is invoked not after the JSP call but somewhere in the application only if any event occurs. below is the code where i wrote to capture cookies.
URL url = new URL("http://localhost:8080");
URLConnection conn = url.openConnection();
conn.getContent();
CookieManager cm = new CookieManager();
CookieHandler.setDefault(cm);
cm.setCookiePolicy(CookiePolicy.ACCEPT_ALL);
CookieStore cs = cm.getCookieStore();
List <HttpCookie> cookies = cs.getCookies();
for (HttpCookie cookie: cookies) {
System.out.println("CookieHandler retrieved cookie: " + cookie);
}
would this scenario works if i want to retrieve the cookies in non servlet class?
The output of the above code will return empty list.
However if i write a servet class with request.getCookie("UserName") I will see the cookie value.
Here i need to understand how would i get the cookie value without using request object.
Because request object is not always passed in multiple invocation of java class. And i am not using session.
please let me know if you have any better approach.
Thanks-
Instead Use the getHeaderFields() method from the connection Object to get the full list of Name-Value pairs representing the header fields of the specific connection
Cookie information(if present)should be under the “Set-Cookie” header field.
Map<String, List<String>> headerFields = conn.getHeaderFields();
Set<String> headerFieldsSet = headerFields.keySet();
Iterator<String> hearerFieldsIter = headerFieldsSet.iterator();
Then iterate over the Set and check if the cookie is present. If it is present print it out.
while (hearerFieldsIter.hasNext()) {
String headerFieldKey = hearerFieldsIter.next();
if ("Set-Cookie".equalsIgnoreCase(headerFieldKey)) {
List<String> headerFieldValue = headerFields.get(headerFieldKey);
for (String headerValue : headerFieldValue) {
System.out.println("Cookie Found...");
String[] fields = headerValue.split(";\s*");
String cookieValue = fields[0];
System.out.println("cookieValue:" + cookieValue);
}
}
}
Y0u can refer this examle
I have stored a js array(key value pair) in cookie using JSON.stringify...
Ex:
var a={"aaa":"111","bbb":222};
document.cookie="mycookie="+JSON.stringify(a);
When I'm reading the cookie from js it returns the value for mycookie as a string {"aaa":"111","bbb":222} so I can parse it again using JSON.parse() and it works fine for me.
My need is to get the same cookie from java.. so I used HttpServletRequest's request.getCookie() method. It returns an array of cookies.. while iterating in to that, it does not have the cookie as "mycookie" instead of that it contains the following cookie list
cookie[0]= aaa:
cookie[1]= bbb:
why it does not return a value as
cookie[0]= mycookie:{"aaa":"111","bbb":222}
how does the getcookie method parses a single cookie in this mannar..
JS:
var dateOfVisiting=new Date().getTime().toString();
var mycookie = {‘page’:’example.com’,‘date’:dateOfVisiting};
var expiryDate = new Date();
expiryDate.setTime(expiryDate.getTime()+(30*24*60*60*1000));
var expires = "; expires="+expiryDate.toGMTString();
document.cookie="mycookie="+JSON.stringify(mycookie)+expires+"; path=/;"
Java
Cookie[] cookies = request.getCookies();
String myData = null;
for(Cookie cookie : cookies){
System.out.println(cookie.getName()+“:”+cookie.getValue());
if(“mycookie”.equals(cookie.getName())){
myData = cookie.getValue();
}
}
The result is
page:
date:
And its not getting inside the if condition
I am using XMLHttpRequest to create a simple form submit and pass 2 parameters. On the server side I am receiving both the parameters but how to get them in different variables?
Here is the Servlet
PrintWriter out = response.getWriter();
response.setContentType("text/plain");
paramMap=request.getParameterMap();
if (paramMap == null)
throw new ServletException(
"getParameterMap returned null in: " + getClass().getName());
iterator=paramMap.entrySet().iterator();
System.out.println(paramMap.size());
String str="";
while(iterator.hasNext())
{
Map.Entry me=(Map.Entry)iterator.next();
String[] arr=(String[])me.getValue();
configId=arr[0];
System.out.println(me.getKey()+" > "+configId);
}
/***Above println** i get "name > Abhishek,filename=a.txt*/
rand=new Random();
randomInt=rand.nextInt(1000000);
configId=randomInt+configId;
System.out.println(configId);
out.println(configId);
/*creates a new session if a session does not exist already*/
session=request.getSession();
session.setAttribute("cid", configId);
out.close();
/*I also need to check a session name `uid` i.e., already created before calling this servlet and then only get both the parameters in parameterMap and store all the params in session. so i'd like to do something like this */
session=request.getSession(false);
if(session!=null) //then get all the parameters here and store them into session
{
uid=session.getAttribute("uid").toString();
/*get nameFromTheParameterMap and fileNameFromTheParameterMap from paramt
session.setAttribute("name", nameFromTheParameterMap);
session.setAttribute("filename", fileNameFromTheParameterMap);
}
Is this the correct approach? Also how will I get parameters from dataString to parameterMap
here is the saveConfig function
function saveConfig()
{
var url_action="/temp/SaveConfig";
var client;
var dataString;
if (window.XMLHttpRequest){ // IE7+, Firefox, Chrome, Opera, Safari
client=new XMLHttpRequest();
} else { // IE6, IE5
client=new ActiveXObject("Microsoft.XMLHTTP");
}
client.onreadystatechange=function(){
if(client.readyState==4&&client.status==200)
{
alert(client.responseText);
}
};
dataString="name="+document.getElementById("name").value+",filename="+document.getElementById("tfile").value;
client.open("POST",url_action,true);
client.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
client.send(dataString);
}
You are wrongly encoding the form-data, you have to seperate the fields by & and not by ,.
See Wikipedia for a summary:
This is a format for encoding key-value pairs with possibly
duplicate keys. Each key-value pair is
separated by an '&' character, and
each key is separated from its value
by an '=' character.
BTW, your Java-Code looks verbose, you could simplify by using for-each-loops.
I am trying to get the access_token from facebook. First I redirect to facebook using an url as the following
https://graph.facebook.com/oauth/authorize?type=user_agent&client_id=7316713919&redirect_uri=http://whomakescoffee.com:8080/app/welcome.jsf&scope=publish_stream
Then I have a listener that gets the url.
FacesContext fc = FacesContext.getCurrentInstance();
HttpServletRequest request =
(HttpServletRequest) fc.getExternalContext().getRequest();
String url = request.getRequestURL().toString();
if (url.contains("access_token")) {
int indexOfEqualsSign = url.indexOf("=");
int indexOfAndSign = url.indexOf("&");
accessToken = url.substring(indexOfEqualsSign + 1, indexOfAndSign);
handleFacebookLogin(accessToken, fc);
}
But it never gets inside the if..
How do I retrieve the parameter when it comes after a # instead of a usual parameter after ?.
The url looks something like
http://benbiddington.wordpress.com/#access_token=
116122545078207|
2.1vGZASUSFMHeMVgQ_9P60Q__.3600.1272535200-500880518|
QXlU1XfJR1mMagHLPtaMjJzFZp4
The URL is incorrectly encoded. It's XML-escaped instead of URL-encoded. The # is a reserved character in URL's which represents the client-side fragment which is never sent back to the server side.
The URL should more look like this:
https://graph.facebook.com/oauth/authorize?type=user_agent&client_id=7316713919&redirect_uri=http%3a%2f%2fwhomakescoffee.com%3a8080%2fapp%2fwelcome.jsf%26scope%3dpublish_stream
You can use java.net.URLEncoder for this.