--- a/progs/app4.scala Mon Sep 23 17:39:31 2013 +0100
+++ b/progs/app4.scala Mon Sep 23 22:23:55 2013 +0100
@@ -2,22 +2,21 @@
val salt = "my secret key"
- //SHA-1, SHA-256 + salt
+ //SHA-1 + salt
def mk_hash(s: String) : String = {
val hash_fun = MessageDigest.getInstance("SHA-1")
hash_fun.digest((s + salt).getBytes).map{ "%02x".format(_) }.mkString
}
- def gt_cookie(c: Option[Cookie]) : Int =
- c.map(_.value.split("/")) match {
- case Some(Array(s, h))
- if (s.forall(_.isDigit) && mk_hash(s) == h) => s.toInt
- case _ => 0
- }
+ def gt_cookie(c: Cookie) : Int = c.value.split("/") match {
+ case Array(s, h)
+ if (s.forall(_.isDigit) && mk_hash(s) == h) => s.toInt
+ case _ => 0
+ }
def mk_cookie(i: Int) : Cookie = {
- val s = i.toString
- Cookie("visits", s + "/" + mk_hash(s))
+ val hash = mk_hash(i.toString)
+ Cookie("visits", s"$i/$hash")
}
def index = Action { request => ... }