本文整理汇总了Scala中org.apache.commons.codec.binary.Base64类的典型用法代码示例。如果您正苦于以下问题:Scala Base64类的具体用法?Scala Base64怎么用?Scala Base64使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了Base64类的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Scala代码示例。
示例1: RSAUtils
//设置package包名称以及导入依赖的类
package com.wix.pay.twocheckout.tokenization
import java.security.KeyFactory
import java.security.spec.RSAPublicKeySpec
import javax.crypto.Cipher
import org.apache.commons.codec.binary.Base64
object RSAUtils {
def rsaEncrypt(key: RSAPublicKey, text: String) = {
val modulus = BigInt(1, Base64.decodeBase64(key.base64Modulus))
val exp = BigInt(1, Base64.decodeBase64(key.base64Exp))
val publicKeySpec = new RSAPublicKeySpec(modulus.bigInteger, exp.bigInteger)
val publicKey = KeyFactory.getInstance("RSA").generatePublic(publicKeySpec)
val cipher = Cipher.getInstance("RSA/ECB/PKCS1PADDING")
cipher.init(Cipher.ENCRYPT_MODE, publicKey)
val res = cipher.doFinal(text.getBytes("UTF-8"))
Base64.encodeBase64String(res)
}
}
case class RSAPublicKey(base64Modulus: String, base64Exp: String)
开发者ID:wix,项目名称:libpay-2checkout,代码行数:26,代码来源:RSAUtils.scala
示例2: RSAUtilsTest
//设置package包名称以及导入依赖的类
package com.wix.pay.twocheckout.tokenization
import java.security.spec.RSAPublicKeySpec
import java.security.{KeyFactory, KeyPairGenerator}
import javax.crypto.Cipher
import org.apache.commons.codec.binary.Base64
import org.specs2.mutable.SpecWithJUnit
import org.specs2.specification.Scope
class RSAUtilsTest extends SpecWithJUnit {
"RSAUtils" should {
"encrypt data with provided key in base64 format" in new Ctx {
val encrypted = RSAUtils.rsaEncrypt(publicKey, someMessage)
decryptBase64(encrypted) mustEqual someMessage
}
"encrypt empty string with provided key in base64 format" in new Ctx {
val encrypted = RSAUtils.rsaEncrypt(publicKey, emptyMessage)
decryptBase64(encrypted) mustEqual emptyMessage
}
}
trait Ctx extends Scope {
val factory = KeyPairGenerator.getInstance("RSA")
factory.initialize(2048)
val keys = factory.genKeyPair()
val publicKeySpec = KeyFactory.getInstance("RSA").getKeySpec(keys.getPublic, classOf[RSAPublicKeySpec])
val publicKey = RSAPublicKey(
Base64.encodeBase64String(publicKeySpec.getModulus.toByteArray),
Base64.encodeBase64String(publicKeySpec.getPublicExponent.toByteArray)
)
println(publicKey)
val someMessage = "some message hello"
val emptyMessage = ""
def decryptBase64(encrypted: String): String = {
val bytes = Base64.decodeBase64(encrypted)
val cipher = Cipher.getInstance("RSA/ECB/PKCS1PADDING")
cipher.init(Cipher.DECRYPT_MODE, keys.getPrivate)
new String(cipher.doFinal(bytes), "utf-8")
}
}
}
开发者ID:wix,项目名称:libpay-2checkout,代码行数:49,代码来源:RSAUtilsTest.scala
示例3: TokenizerRequestBuilder
//设置package包名称以及导入依赖的类
package com.wix.pay.twocheckout.tokenizer
import com.wix.pay.creditcard.CreditCard
import org.apache.commons.codec.binary.Base64
class TokenizerRequestBuilder {
def pretokenRequest(sellerId: String, publishableKey: String) = {
val base64Key = Base64.encodeBase64String(publishableKey.getBytes("utf-8"))
s"""{"sellerId":"$sellerId","publicKey":"$base64Key","userPref":""}"""
}
def tokenRequest(sellerId: String, paymentMethod: String) = {
val base64Method = Base64.encodeBase64String(paymentMethod.getBytes("utf-8"))
s"""{"sellerId":"$sellerId","paymentMethod":"$base64Method"}"""
}
def innerTokenRequest(card: CreditCard, publishableKey: String, preToken: String) = {
val month = card.expiration.month formatted "%02d"
val year = card.expiration.year
val number = card.number
val cvv = card.csc.get
s"""{"paymentMethod":{"cardNum":"$number", "expMonth":"$month", "expYear":"$year", "cvv":"$cvv", "cardType":"CC"},
|"pubAccessKey":"$publishableKey",
|"preToken":"$preToken"}""".stripMargin
}
}
开发者ID:wix,项目名称:libpay-2checkout,代码行数:29,代码来源:TokenizerRequestBuilder.scala
示例4: encrypt
//设置package包名称以及导入依赖的类
package models.user
import javax.crypto.Cipher
import javax.crypto.spec.SecretKeySpec
import org.apache.commons.codec.binary.Base64
import java.security.MessageDigest
import java.util.Arrays
import controllers.HasConfig
trait HasEncryption { self: HasConfig =>
private val CIPHER = "AES/ECB/PKCS5Padding"
private lazy val keySpec = self.config.getString("recogito.email.key").flatMap { key =>
if (key.isEmpty) {
None
} else {
val md = MessageDigest.getInstance("SHA-1")
val keyDigest = md.digest(key.getBytes)
Some(new SecretKeySpec(Arrays.copyOf(keyDigest, 16), "AES"))
}
}
def encrypt(plaintext: String) = keySpec match {
case Some(spec) => {
val cipher = Cipher.getInstance(CIPHER)
cipher.init(Cipher.ENCRYPT_MODE, spec)
Base64.encodeBase64String(cipher.doFinal(plaintext.getBytes("UTF-8")))
}
case None => plaintext
}
def decrypt(encrypted: String) = keySpec match {
case Some(spec) => {
val cipher = Cipher.getInstance(CIPHER)
cipher.init(Cipher.DECRYPT_MODE, spec)
new String(cipher.doFinal(Base64.decodeBase64(encrypted)))
}
case None => encrypted
}
}
开发者ID:pelagios,项目名称:recogito2,代码行数:45,代码来源:HasEncryption.scala
示例5: AuthService
//设置package包名称以及导入依赖的类
package services
import java.security.MessageDigest
import java.util.UUID
import java.util.concurrent.TimeUnit
import model.User
import org.apache.commons.codec.binary.Base64
import org.mindrot.jbcrypt.BCrypt
import play.api.cache.SyncCacheApi
import play.api.mvc.{Cookie, RequestHeader}
import scalikejdbc._
import scala.concurrent.duration.Duration
class AuthService(cacheApi: SyncCacheApi) {
def login(userCode: String, password: String): Option[Cookie] = {
for {
user <- checkUser(userCode, password)
cookie <- Some(createCookie(user))
} yield {
cookie
}
}
def checkCookie(header: RequestHeader): Option[User] = {
for {
cookie <- header.cookies.get(cookieHeader)
user <- cacheApi.get[User](cookie.value)
} yield {
user
}
}
private def checkUser(userCode: String, password: String): Option[User] =
DB.readOnly { implicit session =>
val maybeUser = sql"select * from users where user_code = $userCode".
map(User.fromRS).single().apply()
maybeUser.flatMap { user =>
if (BCrypt.checkpw(password, user.password)) {
Some(user)
} else None
}
}
val mda = MessageDigest.getInstance("SHA-512")
val cookieHeader = "X-Auth-Token"
private def createCookie(user: User): Cookie = {
val randomPart = UUID.randomUUID().toString.toUpperCase
val userPart = user.userId.toString.toUpperCase
val key = s"$randomPart|$userPart"
val token = Base64.encodeBase64String(mda.digest(key.getBytes))
val duration = Duration.create(10, TimeUnit.HOURS)
cacheApi.set(token, user, duration)
Cookie(cookieHeader, token, maxAge = Some(duration.toSeconds.toInt))
}
}
开发者ID:denisftw,项目名称:modern-web-scala,代码行数:61,代码来源:AuthService.scala
示例6: login
//设置package包名称以及导入依赖的类
package controllers
import play.api._
import play.api.mvc._
import play.api.mvc.Results._
import play.api.libs.json._
import org.apache.commons.codec.binary.Base64
import java.util.UUID
import scala.concurrent.Future
trait SessionController extends Controller with Session {
def login = Action.async { req =>
req.headers.get("Authorization").map { auth =>
val userpass = decodeBase64(auth.split(" ").tail.head).split(":")
val (user, pass) = (userpass.headOption, userpass.drop(1).headOption.getOrElse(""))
user.map { us =>
if (us == "login" && pass == "password") {
val uuid = UUID.randomUUID.toString
saveAccessTokenForUser(uuid, us)
Future.successful(Ok(uuid))
}
else {
futureUnauthorized
}
} getOrElse futureUnauthorized
} getOrElse futureUnauthorized
}
private val futureUnauthorized = Future.successful(Unauthorized)
private def decodeBase64(str: String) = new String(Base64.decodeBase64(str), "UTF-8")
}
trait Session {
private var sessionMap = new java.util.concurrent.ConcurrentHashMap[String, String]
def saveAccessTokenForUser(token: String, user: String) = sessionMap.put(token, user)
def getUserForAccessToken(token: String) = {
val r = sessionMap.get(token)
if ( r == null)
None
else
Some(r)
}
}
object SessionController extends SessionController
开发者ID:clrvynt,项目名称:s3upload,代码行数:47,代码来源:SessionController.scala
示例7: StringUtils
//设置package包名称以及导入依赖的类
package utils
import org.apache.commons.codec.binary.Base64
object StringUtils {
implicit class StringUtilsExtensions(val self: String) extends AnyVal {
def stripMargins(margin: String): String = self.stripPrefix(margin).stripSuffix(margin)
}
implicit class ByteArrayToBase64StringExtensions(val array: Array[Byte]) extends AnyVal {
def asBase64(): String = Base64.encodeBase64String(array)
}
implicit class ByteArrayFromBase64StringExtensions(val string: String) extends AnyVal {
def fromBase64(): Array[Byte] = Base64.decodeBase64(string)
}
}
开发者ID:lymr,项目名称:fun-chat,代码行数:18,代码来源:StringUtils.scala
示例8: SignatureAlgorithm
//设置package包名称以及导入依赖的类
package me.laiseca.oauth1.client.core.model
import me.laiseca.oauth1.client.core.Defaults
import me.laiseca.oauth1.client.core.util.UrlEncode
import org.apache.commons.codec.binary.Base64
import org.apache.commons.codec.digest.HmacUtils
abstract class SignatureAlgorithm(val name: String) {
def digest(text: String, consumerSecret: Option[String], tokenSecret: Option[String]): String = {
assert(consumerSecret.isDefined || tokenSecret.isDefined)
val d = digest(
key(consumerSecret, tokenSecret).getBytes(Defaults.Charset),
text.getBytes(Defaults.Charset))
val digest64 = new Base64(0).encode(d)
new String(digest64, Defaults.Charset)
}
private[this] def key(consumerSecret: Option[String], tokenSecret: Option[String]): String = concat {
UrlEncode.encode(List(consumerSecret.getOrElse(""), tokenSecret.getOrElse("")))
}
private[this] def concat(items: Iterable[String]): String = items.mkString("&")
protected def digest(key: Array[Byte], text: Array[Byte]): Array[Byte]
}
case object HmacSHA1 extends SignatureAlgorithm("HMAC-SHA1") {
override protected def digest(key: Array[Byte], text: Array[Byte]): Array[Byte] =
HmacUtils.hmacSha1(key, text)
}
case object HmacSHA256 extends SignatureAlgorithm("HMAC-SHA256") {
override protected def digest(key: Array[Byte], text: Array[Byte]): Array[Byte] =
HmacUtils.hmacSha256(key, text)
}
开发者ID:xabierlaiseca,项目名称:oauth1-client-core,代码行数:39,代码来源:SignatureAlgorithm.scala
示例9: Key
//设置package包名称以及导入依赖的类
package models
import java.nio.ByteBuffer
import java.security.SecureRandom
import net.glxn.qrgen._
import org.apache.commons.codec.binary.{Base32, Base64}
import play.api.Play
object Key {
val sr = new SecureRandom
val config = Play.current.configuration
val size = config.getInt("qrCode.size").getOrElse(160)
def next: String = {
var bb = ByteBuffer.allocate(8)
sr.nextBytes(bb.array)
val token = bb.getLong
token.abs.toHexString
}
def urlImage(key: String) : String = {
// data uris require base64 encoding of data
// ie: <img src="">
val url = s"http://www.onceness.com/msg/$key"
val data = new String(Base64.encodeBase64(QRCode.from(url).withSize(size,size).stream().toByteArray))
data
}
def msgImage(msg: String) : String = {
// data uris require base64 encoding of data
// ie: <img src="">
val data = new String(Base64.encodeBase64(QRCode.from(msg).withSize(size,size).stream().toByteArray))
data
}
}
开发者ID:n0n3such,项目名称:r1ms,代码行数:40,代码来源:Key.scala
示例10: BasicAuthorization
//设置package包名称以及导入依赖的类
package util
import org.apache.commons.codec.binary.Base64
object BasicAuthorization {
trait Authorization
case class Token(token: String) extends Authorization
def get(value: Option[String]): Option[Authorization] = {
value.flatMap { get(_) }
}
def get(value: String): Option[Authorization] = {
value.split(" ").toList match {
case "Basic" :: value :: Nil => {
new String(Base64.decodeBase64(value.getBytes)).split(":").toList match {
case Nil => None
case token :: rest => Some(Token(token))
}
}
case _ => None
}
}
}
开发者ID:flowcommerce,项目名称:splashpage,代码行数:28,代码来源:BasicAuthorization.scala
示例11: NormalizationHandler
//设置package包名称以及导入依赖的类
package com.fustigatedcat.heystk.engine.normalization
import java.io.ByteArrayInputStream
import java.util.zip.GZIPInputStream
import com.fustigatedcat.heystk.common.normalization.Normalization
import com.fustigatedcat.heystk.engine.queue.RabbitQueue
import org.apache.commons.codec.binary.Base64
import org.apache.commons.codec.digest.DigestUtils
import org.apache.commons.io.IOUtils
import org.json4s.native.JsonMethods.parse
import org.slf4j.LoggerFactory
object NormalizationHandler {
val logger = LoggerFactory.getLogger(this.getClass)
implicit val formats = org.json4s.DefaultFormats
def checksum(string : String) : String = {
DigestUtils.sha256Hex(string)
}
def unzip(string : String) : String = {
val arr = Base64.decodeBase64(string)
val gis = new GZIPInputStream(new ByteArrayInputStream(arr))
IOUtils.toString(gis, "UTF-8")
}
def handle(string : String, chksm : String) = {
val body = unzip(string)
if(checksum(body) == chksm) {
// write normalization to temp DB and post to Queue for needs processing
parse(unzip(string)).extract[List[Normalization]].par.foreach(RabbitQueue.postToProcess)
} else {
logger.error(s"Invalid checksum ${checksum(body)} != $chksm")
}
}
}
开发者ID:fustigatedcat,项目名称:heystk,代码行数:42,代码来源:NormalizationHandler.scala
示例12: BasicAuthTokenAccessor
//设置package包名称以及导入依赖的类
package controllers.basic
import jp.t2v.lab.play2.auth.{AuthenticityToken, TokenAccessor}
import play.api.mvc.{Result, RequestHeader}
import org.apache.commons.codec.binary.Base64
import java.nio.charset.Charset
class BasicAuthTokenAccessor extends TokenAccessor {
override def delete(result: Result)(implicit request: RequestHeader): Result = result
override def put(token: AuthenticityToken)(result: Result)(implicit request: RequestHeader): Result = result
override def extract(request: RequestHeader): Option[AuthenticityToken] = {
val encoded = for {
h <- request.headers.get("Authorization")
if h.startsWith("Basic ")
} yield h.substring(6)
encoded.map(s => new String(Base64.decodeBase64(s), Charset.forName("UTF-8")))
}
}
开发者ID:phosphene,项目名称:play2.x-basic-auth-demo,代码行数:23,代码来源:BasicAuthTokenAccessor.scala
示例13: JavaUUIDs
//设置package包名称以及导入依赖的类
package effectful.examples.pure.uuid.impl
import java.nio.ByteBuffer
import java.util.{UUID => JavaUUID}
import cats.Id
import effectful.examples.pure.uuid.UUIDs
import org.apache.commons.codec.binary.Base64
import scala.util.Try
class JavaUUIDs extends UUIDs[Id] {
import UUIDs._
implicit val print : UUID => String = toString(_)
def toUUID(uuid: JavaUUID) = UUID(toBytes(uuid))
def toBytes(uuid: JavaUUID) : Array[Byte] = {
val bb = ByteBuffer.allocate(16)
bb.putLong(uuid.getMostSignificantBits)
bb.putLong(uuid.getLeastSignificantBits)
bb.array()
}
def toJavaUUID(uuid: UUID) : JavaUUID = {
val bb = ByteBuffer.wrap(uuid.bytes.toArray)
val msb = bb.getLong
val lsb = bb.getLong
new JavaUUID(msb,lsb)
}
override def gen(): Id[UUID] =
toUUID(JavaUUID.randomUUID())
override def toString(uuid: UUID): String =
toJavaUUID(uuid).toString
override def fromBase64(s: String): Option[UUID] = {
val uuid = UUID(Base64.decodeBase64(s))
Try(toJavaUUID(uuid)).toOption.map(_ => uuid)
}
override def toBase64(uuid: UUID): String =
Base64.encodeBase64URLSafeString(uuid.bytes.toArray)
override def fromString(s: String): Id[Option[UUID]] =
Try(JavaUUID.fromString(s)).toOption.map(toUUID)
}
开发者ID:S-Mach,项目名称:effectful,代码行数:51,代码来源:JavaUUIDs.scala
示例14: Bytes
//设置package包名称以及导入依赖的类
package com.avsystem.scex.util
import java.io.UnsupportedEncodingException
import java.nio.charset.StandardCharsets
import com.avsystem.commons.jiop.JavaInterop._
import com.avsystem.scex.presentation.annotation.Documentation
import org.apache.commons.codec.binary.{Base64, Hex}
import scala.collection.mutable
import scala.util.hashing.MurmurHash3
final class Bytes(val bytes: Array[Byte]) extends Comparable[Bytes] {
override def hashCode(): Int = MurmurHash3.bytesHash(bytes)
override def equals(other: Any): Boolean = other match {
case b: Bytes => java.util.Arrays.equals(bytes, b.bytes)
case _ => false
}
override def toString: String = s"Bytes($escaped)"
override def compareTo(o: Bytes): Int = {
def loop(i: Int): Int =
if (i == bytes.length && i == o.bytes.length) 0
else if (i == bytes.length) -1
else if (i == o.bytes.length) 1
else {
val b1 = bytes(i)
val b2 = o.bytes(i)
if (b1 == b2) loop(i + 1) else b1 - b2
}
loop(0)
}
@Documentation("Encodes this sequence of bytes as string with non-ASCII bytes and backslash escaped, e.g. 'hsg\\x7c\\x0dfoo\\\\bar'")
def escaped: String = EscapedBytes.render(bytes)
@Documentation("Encodes this sequence of bytes as hexadecimal string")
def hex: String = Hex.encodeHexString(bytes)
@Documentation("Encodes this sequence of bytes as BASE64 string")
def base64: String = Base64.encodeBase64String(bytes)
@Documentation("Decodes this sequence of bytes as UTF-8 string")
def decodeUTF8: String = new String(bytes, StandardCharsets.UTF_8)
@Documentation("Decodes this sequence of bytes as string using given charset")
def decode(charset: String): String =
try new String(bytes, charset) catch {
case e: UnsupportedEncodingException => throw new IllegalArgumentException(e)
}
def asList: JList[Byte] = new mutable.WrappedArray.ofByte(bytes).asJava
}
开发者ID:AVSystem,项目名称:scex,代码行数:53,代码来源:Bytes.scala
示例15: Encryption
//设置package包名称以及导入依赖的类
package me.flygare.utils
import java.security.MessageDigest
import java.util
import javax.crypto.Cipher
import javax.crypto.spec.SecretKeySpec
import org.apache.commons.codec.binary.Base64
object Encryption {
def encrypt(key: String, value: String): String = {
val cipher: Cipher = Cipher.getInstance("AES/ECB/PKCS5Padding")
cipher.init(Cipher.ENCRYPT_MODE, keyToSpec(key))
Base64.encodeBase64String(cipher.doFinal(value.getBytes("UTF-8")))
}
def decrypt(key: String, encryptedValue: String): String = {
val cipher: Cipher = Cipher.getInstance("AES/ECB/PKCS5PADDING")
cipher.init(Cipher.DECRYPT_MODE, keyToSpec(key))
new String(cipher.doFinal(Base64.decodeBase64(encryptedValue)))
}
def keyToSpec(key: String): SecretKeySpec = {
var keyBytes: Array[Byte] = (SALT + key).getBytes("UTF-8")
val sha: MessageDigest = MessageDigest.getInstance("SHA-256")
keyBytes = sha.digest(keyBytes)
keyBytes = util.Arrays.copyOf(keyBytes, 16)
new SecretKeySpec(keyBytes, "AES")
}
private val SALT: String =
"1b9d370a82ba55843b71030c6b22bd88f8ae12d328c3154314272c995c2ce7b7"
}
开发者ID:flygare,项目名称:Minopt,代码行数:34,代码来源:Encryption.scala
示例16: Encryption
//设置package包名称以及导入依赖的类
package me.flygare.utils
import java.security.MessageDigest
import java.util
import javax.crypto.Cipher
import javax.crypto.spec.SecretKeySpec
import org.apache.commons.codec.binary.Base64
object Encryption {
def encrypt(key: String, value: String): String = {
val cipher: Cipher = Cipher.getInstance("AES/ECB/PKCS5Padding")
cipher.init(Cipher.ENCRYPT_MODE, keyToSpec(key))
Base64.encodeBase64String(cipher.doFinal(value.getBytes("UTF-8")))
}
def decrypt(key: String, encryptedValue: String): String = {
val cipher: Cipher = Cipher.getInstance("AES/ECB/PKCS5PADDING")
cipher.init(Cipher.DECRYPT_MODE, keyToSpec(key))
new String(cipher.doFinal(Base64.decodeBase64(encryptedValue)))
}
def keyToSpec(key: String): SecretKeySpec = {
var keyBytes: Array[Byte] = (SALT + key).getBytes("UTF-8")
val sha: MessageDigest = MessageDigest.getInstance("SHA-256")
keyBytes = sha.digest(keyBytes)
keyBytes = util.Arrays.copyOf(keyBytes, 16)
new SecretKeySpec(keyBytes, "AES")
}
private val SALT: String =
"1b9d370a82ba55843b71030c6b22bd88f8ae12d328c3154314272c995c2ce7b7"
}
开发者ID:flygare,项目名称:Minopt,代码行数:33,代码来源:Encryption.scala
示例17: LoadFile
//设置package包名称以及导入依赖的类
package loadFile
import java.io.{BufferedInputStream, FileInputStream}
import java.nio.file.{Files, Paths}
import language.experimental.macros
import scala.reflect.macros.blackbox.Context
import scala.io.Source
import org.apache.commons.codec.binary.Base64
import org.apache.commons.io.IOUtils
object LoadFile {
def syncLoad(fileName: String): String = macro syncLoadImpl
def syncLoadImpl(c: Context)(fileName: c.Expr[String]): c.Expr[String] = {
import c.universe._
val Literal(Constant(fileNameStr)) = fileName.tree
val fileContents = Source.fromFile("./server/public/" + fileNameStr).getLines.mkString("\n")
c.Expr[String](Literal(Constant(fileContents)))
}
def toBase64(fileName: String): String = macro toBase64Impl
def toBase64Impl(c: Context)(fileName: c.Expr[String]): c.Expr[String] = {
import c.universe._
val Literal(Constant(fileNameStr)) = fileName.tree
return c.Expr[String](Literal(Constant(new String(""))))
//val bis = new BufferedInputStream(new FileInputStream("./server/public/" + fileNameStr))
// Get byte array for base64 encoding
//val fileBytes = Stream.continually(bis.read).takeWhile(-1 != _).map(_.toByte).toArray
//val fileBytes = IOUtils.toByteArray(bis)
val fileBytes = Files.readAllBytes(Paths.get("./server/public/" + fileNameStr))
c.Expr[String](Literal(Constant(new String(Base64.encodeBase64(fileBytes)))))
}
}
开发者ID:gvatn,项目名称:play-scalajs-webgl-spark,代码行数:36,代码来源:LoadFile.scala
示例18: BaseAction
//设置package包名称以及导入依赖的类
package action
import domains.TransportRequest
import org.apache.commons.codec.binary.Base64
import play.api.Logger
import play.api.libs.json.{JsValue, Json}
import play.api.mvc._
import request.BaseRequest
import utils.RSA
import utils.crypto.AES
import scala.concurrent.Future
object BaseAction extends ActionBuilder[BaseRequest] {
def transform[A](request: Request[A]) = {
val transportRequest: TransportRequest = request.body match {
case null => null
case body: AnyContentAsText =>
val content: JsValue = Json.parse(new String(AES.decrypt(Base64.decodeBase64(body.asText.orNull), AES.AES_KEY)))
val publicKey: String = (content \ "publicKey").get.toString()
val info: String = content \ "info" toOption match {
case None => null
case a => new String(RSA.decryptByPublicKey(Base64.decodeBase64(a.get.toString()), publicKey))
}
TransportRequest(publicKey, Option(info))
}
new BaseRequest(transportRequest, request)
}
def invokeBlock[A](request: Request[A], block: (BaseRequest[A]) => Future[Result]): Future[Result] = {
val res = transform(request)
Logger.debug("decrypted request body: \n%s".format(res.transportRequest))
block(res)
}
}
开发者ID:JasonRock,项目名称:xpass,代码行数:41,代码来源:BaseAction.scala
示例19: AESDecrypt
//设置package包名称以及导入依赖的类
package controllers
import javax.inject._
import action.BaseAction
import domains._
import org.apache.commons.codec.binary.Base64
import play.api.libs.json._
import play.api.mvc._
import utils.RSA
def AESDecrypt() = BaseAction {
request => {
val encryptedData = request.transportRequest
Ok(Json.toJson(encryptedData))
}
}
val publicKey: String = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDbq7UBSlyc0aYkIMdA3nGDUjBHOiUWeS84EYUwxzyZZ" +
"2+ItVIyOEvxh79x3vRSmw9W2GqUfda60VxT+0JJu92a3OVYjjjatMfD9SSsfPmFJRYcwmljhR0nb+hod2u" +
"NGxDxWSevYCs2Nj4H1oq/P+NKsxtKfKmIhnmQ8PBPyFgXUQIDAQAB"
val privateKey: String = "MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBANurtQFKXJzRpiQg" +
"x0DecYNSMEc6JRZ5LzgRhTDHPJlnb4i1UjI4S/GHv3He9FKbD1bYapR91rrRXFP7" +
"Qkm73Zrc5ViOONq0x8P1JKx8+YUlFhzCaWOFHSdv6Gh3a40bEPFZJ69gKzY2PgfW" +
"ir8/40qzG0p8qYiGeZDw8E/IWBdRAgMBAAECgYEA1ix2gPiYjUkWnFjdDFEVCX1j" +
"lr6JFH043YivfFx0p/iiVP68UjxzRt0cehBv0+5cqUa9u2NpraGcTEFIYw1ow9sm" +
"UBoxbvQsm9mRTB1Ut2PvJXinFNb1z+bdT3RYU3tADNUn7MIgsqvyZWH2WUZXMZgu" +
"qXzGklEZDuTE3tmg2fECQQDxeTT+plmt8O2DbSoR/JCPs5st0vcDCSKXGhTeDjBw" +
"suAAeH0Wc8gcFdV2tESbArwzNIhKjLe6d5hGm+RG90PdAkEA6OK6j9OYn0xe6DkU" +
"SUItCSk1VaLVeAgLUZA+0KR9ODavHZH4QRzj4pluADqglyIYKN9P2ZgHj/cvn1tn" +
"muiUBQJAaqQ72kZ/Dol7a3J3hPAEq+IHI0qrGiUbqJ21H4gmrm7g7HRJ0fOaKYUe" +
"+8iLD+Y6VWba1gmlTm1oy64nN4wV5QJAS9ItfVAdu5douuCCi0thUD87XxMxvu+X" +
"h8mXueQj5J5hKxZwJfra8taTKr3rtOjjxsLVw3ks1SFcPtzKgXPBZQJBALiUQJII" +
"mEVsbF0SyQMk/4OnPf4urGuJYdKr4bX/j5I779t7yKZTRipm2N14KLDs3qPAKnYc" +
"LXkL138RiPfXDNM="
def RSAEncrypt() = Action(BodyParsers.parse.json) {
request => {
val encrypted: String = Base64.encodeBase64String(
RSA.encryptByPublicKey(request.body.toString().getBytes, publicKey))
Ok(encrypted)
}
}
def RSADecrypt() = Action {
request => {
val encryptedData = request.body.asText.orNull
Ok(new String(RSA.decryptByPrivateKey(Base64.decodeBase64(encryptedData), privateKey)))
}
}
}
开发者ID:JasonRock,项目名称:xpass,代码行数:56,代码来源:EncryptController.scala
示例20: JavaUUIDs
//设置package包名称以及导入依赖的类
package effectful.examples.pure.uuid.impl
import java.nio.ByteBuffer
import java.util.{UUID => JavaUUID}
import cats._
import effectful.examples.pure.uuid.UUIDs
import org.apache.commons.codec.binary.Base64
import scala.util.Try
class JavaUUIDs extends UUIDs[Id] {
import UUIDs._
implicit val print : UUID => String = toString(_)
def toUUID(uuid: JavaUUID) = UUID(toBytes(uuid))
def toBytes(uuid: JavaUUID) : Array[Byte] = {
val bb = ByteBuffer.allocate(16)
bb.putLong(uuid.getMostSignificantBits)
bb.putLong(uuid.getLeastSignificantBits)
bb.array()
}
def toJavaUUID(uuid: UUID) : JavaUUID = {
val bb = ByteBuffer.wrap(uuid.bytes.toArray)
val msb = bb.getLong
val lsb = bb.getLong
new JavaUUID(msb,lsb)
}
override def gen(): Id[UUID] =
toUUID(JavaUUID.randomUUID())
override def toString(uuid: UUID): String =
toJavaUUID(uuid).toString
override def fromBase64(s: String): Option[UUID] = {
val uuid = UUID(Base64.decodeBase64(s))
Try(toJavaUUID(uuid)).toOption.map(_ => uuid)
}
override def toBase64(uuid: UUID): String =
Base64.encodeBase64URLSafeString(uuid.bytes.toArray)
override def fromString(s: String): Id[Option[UUID]] =
Try(JavaUUID.fromString(s)).toOption.map(toUUID)
}
开发者ID:lancegatlin,项目名称:effectful-demo,代码行数:51,代码来源:JavaUUIDs.scala
注:本文中的org.apache.commons.codec.binary.Base64类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论