I`m almost done with my DH key exchange application. I am now trying to authenticate my client on my application. However, I keep getting a null pointer exception on my server. I traced the problem to my big integer variable but I do not see any problem with it.
I am trying to send a response of a 1 or 0 to the client. 1 indicates authenticated and 0 not authenticated
I will show the parts where the error occurred
DHServlet.java
public class DHServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
private static String pk2;
private static String pCValue;
private static String gCValue;
private static String sCValue;
protected void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
// PrintWriter out2=response.getWriter();
DH getDH = new DH();
try {
String un,pw,pk;
Random randomGenerator = new Random();
long pValue = randomGenerator.nextInt(100000000);
long gValue = randomGenerator.nextInt(100000000);
boolean checkPrime = getDH.isPrime(pValue);
while(checkPrime == false)
{
long generatePValue2 = randomGenerator.nextInt(10000000);
boolean checkPrime2 = getDH.isPrime(generatePValue2);
if(checkPrime2==true)
{
pValue=generatePValue2;
break;
}
}
long checkSP = (pValue*2)+1;
boolean checkSafePrime = getDH.isPrime(checkSP);
while(checkSafePrime == false)
{
long generatePValue3 = randomGenerator.nextInt(100000000);
boolean checkSpInLoop = getDH.isPrime(generatePValue3);
long checkSP2 = (generatePValue3*2)+1;
boolean checkSafePrimeInLoop = getDH.isPrime(checkSP2);
if(checkSpInLoop == true && checkSafePrimeInLoop == true)
{
pValue = generatePValue3;
break;
}
}
while(gValue>pValue)
{
long gValue2=randomGenerator.nextInt(100000000);
if(gValue2<pValue)
{
gValue=gValue2;
break;
}
}
long getDivisor =(pValue-1)/2;
BigInteger bi1,bi2,bi3,bi4;
bi1=BigInteger.valueOf(getDivisor);
bi2=BigInteger.valueOf(pValue);
bi3=BigInteger.valueOf(gValue);
bi4=bi3.modPow(bi1,bi2);
long calculatedValue = bi4.longValue();
while(calculatedValue == 1)
{
long gValue3=randomGenerator.nextInt(100000000);
long getDivisorInLoop = (pValue-1)/2;
BigInteger bi5,bi6,bi7,bi8;
bi5=BigInteger.valueOf(getDivisorInLoop);
bi6=BigInteger.valueOf(pValue);
bi7=BigInteger.valueOf(gValue3);
bi8=bi7.modPow(bi5, bi6);
long calculatedValueInLoop = bi8.longValue();
if(calculatedValueInLoop != 1)
{
gValue=gValue3;
break;
}
}
BigInteger generatorValue,primeValue,skA,biPKA;
generatorValue = BigInteger.valueOf(gValue);
primeValue = BigInteger.valueOf(pValue);
long secretKeyA = getDH.generateSKA();
skA=BigInteger.valueOf(secretKeyA);
biPKA =getDH.generatePkA(generatorValue, primeValue, secretKeyA);
System.out.println("The public key of server is "+biPKA);
System.out.println("The generator value is "+generatorValue);
System.out.println("The prime value is "+primeValue);
System.out.println("the secret key of the server is "+skA);
long PKA = biPKA.longValue();
out.print(pValue+":"+gValue+":"+PKA);
pk2=biPKA.toString();
pCValue=primeValue.toString();
gCValue=generatorValue.toString();
sCValue=skA.toString();
} finally {
out.close();
}
}
protected void processRequest2(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
{
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
DH getDH2=new DH();
String un,pw,pk,shareK;
try
{
pk=request.getParameter("publicK");
un=request.getParameter("username");
pw=request.getParameter("password");
shareK=request.getParameter("sharedKey");
String publicKey = pk;
BigInteger biPK,biSK,biP,sKey;
biPK = new BigInteger(publicKey);
biSK = new BigInteger(sCValue);
biP = new BigInteger(pCValue);
System.out.println(biPK);
sKey = getDH2.calculateSharedKey(biPK, biSK, biP);
String sharedServerKey = (sKey.toString()).trim();
System.out.println("the shared key is "+sharedServerKey);
if(un.equalsIgnoreCase("larry")&& pw.equals("123") && sharedServerKey == shareK)
{
out.print(1);
}
else
{
out.print(0);
}
}finally
{
out.close();
}
}
/**
* @see HttpServlet#HttpServlet()
*/
public DHServlet() {
super();
// TODO Auto-generated constructor stub
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
processRequest(request,response);
processRequest2(request,response);
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
processRequest2(request,response);
}
}
My Tomcat log:
Jul 12, 2013 10:10:07 PM org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Servlet.service() for servlet [DHServlet] in context with path [/MyServletProject] threw exception
java.lang.NullPointerException
at java.math.BigInteger.<init>(Unknown Source)
at java.math.BigInteger.<init>(Unknown Source)
at DHServlet.processRequest2(DHServlet.java:158)
at DHServlet.doGet(DHServlet.java:202)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:164)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:395)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:250)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
Hope you guys can help me with this, I'm just stumped. Thanks in advance.
EDIT : i updated my servlet code.
The Exception is clear:
pk=request.getParameter("publicK");
un=request.getParameter("username");
pw=request.getParameter("password");
shareK=request.getParameter("sharedKey");
BigInteger biPK,biSK,biP,sKey;
biPK = new BigInteger(pk);
biSK = new BigInteger(sCValue);
biP = new BigInteger(pCValue);
You're getting a NullPointerException
since any of your variables, pk
, sCValue
, pCValue
is null
.
By the way, where does your variables sCValue
and pCValue
get initialized?
你的stacktrace说你的BigIntegers有一个问题(pk,un或pw中的一个是null)
In this case the NullPointerException occurs because you pass a value of null
to the constructor of BigInteger
.
The stacktrace tells you the line number in which you call it: DHServlet.java:158
.
Assuming the line is the following
biPK = new BigInteger(pk);
then pk
is null.
You are probably using null
String to instantiate BigInteger
.Any or All of the request parameters are null
.
pk=request.getParameter("publicK");
un=request.getParameter("username");
pw=request.getParameter("password");
One of these variables: pk, sCValue or pCValue
is null
since i don't know what the line 158 in the Servlet
is?
You can't instantiate a BigInteger
with null as argument.
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.