当前位置: 首页>>代码示例>>Scala>>正文


Scala ServletContext类代码示例

本文整理汇总了Scala中javax.servlet.ServletContext的典型用法代码示例。如果您正苦于以下问题:Scala ServletContext类的具体用法?Scala ServletContext怎么用?Scala ServletContext使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


在下文中一共展示了ServletContext类的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Scala代码示例。

示例1: probeForCycleClass

//设置package包名称以及导入依赖的类
#set( $symbol_pound = '#' )
#set( $symbol_dollar = '$' )
#set( $symbol_escape = '\' )
package ${package}

import javax.servlet.ServletContext

import nl.knaw.dans.lib.logging.DebugEnhancedLogging
import org.eclipse.jetty.ajp.Ajp13SocketConnector
import org.eclipse.jetty.server.Server
import org.eclipse.jetty.servlet.ServletContextHandler
import org.scalatra._
import org.scalatra.servlet.ScalatraListener

import scala.util.Try

class ${javaName}Service(serverPort: Int, app: ${javaName}App) extends DebugEnhancedLogging {
  import logger._

  private val server = new Server(serverPort)
  private val context = new ServletContextHandler(ServletContextHandler.NO_SESSIONS)
  context.addEventListener(new ScalatraListener() {
    override def probeForCycleClass(classLoader: ClassLoader): (String, LifeCycle) = {
      ("anonymous", new LifeCycle {
        override def init(context: ServletContext): Unit = {
          context.mount(new ${javaName}Servlet(app), "/")
        }
      })
    }
  })
  server.setHandler(context)
  info(s"HTTP port is ${symbol_dollar}{serverPort}")

  def start(): Try[Unit] = Try {
    info("Starting service...")
    server.start()
  }

  def stop(): Try[Unit] = Try {
    info("Stopping service...")
    server.stop()
  }

  def destroy(): Try[Unit] = Try {
    server.destroy()
    app.close()
  }
} 
开发者ID:DANS-KNAW,项目名称:easy-module-archetype,代码行数:49,代码来源:__javaName__Service.scala

示例2: ScalatraBootstrap

//设置package包名称以及导入依赖的类
import javax.servlet.ServletContext

import akka.actor.{ActorSystem, Props}
import com.innoq.integration.{InterceptionController, InterceptionHandler, Launcher, MockController}
import org.scalatra.LifeCycle

class ScalatraBootstrap extends LifeCycle {
  override def init(context: ServletContext) {
    val actorSystem = ActorSystem("test-server")

    val interceptionHandler = actorSystem.actorOf(Props[InterceptionHandler])

    try {
      context.mount(new InterceptionController(actorSystem, interceptionHandler), "/interceptions/*")
      context.mount(new MockController(actorSystem, interceptionHandler), "/mocks/*")
    } catch {
      case e: Throwable =>
        Launcher.stopServer()
        throw e
    }
  }
} 
开发者ID:mputz86,项目名称:testing-with-logging,代码行数:23,代码来源:ScalatraBootstrap.scala

示例3: Plugin

//设置package包名称以及导入依赖的类
import javax.servlet.ServletContext

import gitbucket.core.plugin.PluginRegistry
import gitbucket.core.service.SystemSettingsService.SystemSettings
import gitbucket.html5media.{Html5VideoRenderer, Html5AudioRenderer, PDFRenderer}
import io.github.gitbucket.solidbase.model.Version

class Plugin extends gitbucket.core.plugin.Plugin {
  override val pluginId: String = "html5media"
  override val pluginName: String = "HTML5 media Plugin"
  override val description: String = "Provides HTML5 video/audio player and PDF viewer for GitBucket."
  override val versions: List[Version] = List(
    new Version("1.0.0"),
    new Version("1.0.1")
  )

  override def initialize(registry: PluginRegistry, context: ServletContext, settings: SystemSettings): Unit = {
    val html5v = new Html5VideoRenderer()
    val html5a = new Html5AudioRenderer()
    val pdf = new PDFRenderer()
    registry.addRenderer("mp4", html5v)
    registry.addRenderer("webm", html5v)
    registry.addRenderer("ogv", html5v)
    registry.addRenderer("mp3", html5a)
    registry.addRenderer("aac", html5a)
    registry.addRenderer("ogg", html5a)
    registry.addRenderer("flac", html5a)
    registry.addRenderer("wav", html5a)
    registry.addRenderer("pdf", pdf)
    super.initialize(registry, context, settings)
  }
} 
开发者ID:kounoike,项目名称:gitbucket-html5media-plugin,代码行数:33,代码来源:Plugin.scala

示例4: ScalatraBootstrap

//设置package包名称以及导入依赖的类
package com.pagerduty.scheduler.admin.http.standalone

import javax.servlet.ServletContext

import com.pagerduty.scheduler.Scheduler
import com.pagerduty.scheduler.admin.AdminService
import com.pagerduty.scheduler.admin.http.{AdminServlet, Settings}
import org.scalatra.LifeCycle


class ScalatraBootstrap extends LifeCycle {
  override def init(context: ServletContext) {
    val adminService = context.getAttribute(AdminHttpServer.AdminServiceAttributeKey)
    val settings = context.getAttribute(AdminHttpServer.SettingsAttributeKey)

    (adminService, settings) match {
      case (service: AdminService, settings: Settings) =>
        context mount (new AdminServlet(service), s"/${settings.apiNamespace}/*")
      case _ =>
        throw new RuntimeException("Couldn't start Admin HTTP server without dependencies!")
    }

  }
} 
开发者ID:PagerDuty,项目名称:scheduler,代码行数:25,代码来源:ScalatraBootstrap.scala

示例5: ScalatraBootstrap

//设置package包名称以及导入依赖的类
package com.github.twinra.lendmanager.rest

import javax.servlet.ServletContext

import com.github.twinra.lendmanager.dao.LendingRepository
import com.github.twinra.lendmanager.repo.{ItemRepository, PersonRepository}
import org.scalatra.LifeCycle
import scalikejdbc.config.DBs

class ScalatraBootstrap extends LifeCycle {
  override def init(context: ServletContext) {
    DBs.setup()
    implicit val itemsRepo = new ItemRepository {
      init()
    }
    implicit val peopleRepo = new PersonRepository {
      init()
    }
    implicit val lendingsRepo = new LendingRepository {
      init()
    }

    context.mount(new PeopleServlet, "/people/*")
    context.mount(new ItemsServlet, "/items/*")
    context.mount(new LendingsServlet, "/lendings/*")
  }

  override def destroy(context: ServletContext): Unit = DBs.closeAll()
} 
开发者ID:twinra,项目名称:lending-manager,代码行数:30,代码来源:ScalatraBootstrap.scala

示例6: ScalatraBootstrap

//设置package包名称以及导入依赖的类
package jp.seraphr.fileupload.main

import javax.servlet.ServletContext

import jp.seraphr.fileupload.FileUploadApi
import jp.seraphr.fileupload.model.UploadSettings
import org.scalatra.{ LifeCycle, ScalatraServlet }
import upickle.Api


class ScalatraBootstrap extends LifeCycle {
  class FileUploadServlet extends ScalatraServlet with FileUploadApi {
    override protected val settings: UploadSettings = UploadSettings("fileparam")
    override val jsonApi: Api = upickle.default
  }

  override def init(context: ServletContext): Unit = {
    val tServlet = new FileUploadServlet
    context.mount(tServlet, "/fileupload")
  }
} 
开发者ID:seraphr,项目名称:scalatra-reactjs-fileupload,代码行数:22,代码来源:ScalatraBootstrap.scala

示例7: ScalatraBootstrap

//设置package包名称以及导入依赖的类
import javax.servlet.ServletContext

import com.typesafe.scalalogging.LazyLogging
import org.scalatra.{LifeCycle}

import io.aigar.controller.{AdminController, GameController, LeaderboardController}
import io.aigar.game.GameThread
import io.aigar.model.PlayerRepository
import io.aigar.score.ScoreThread

object ScalatraBootstrap {
  final val PasswordLength = 28
}

class ScalatraBootstrap extends LifeCycle
                        with LazyLogging {
  logger.info("Bootstrapping application.")
  var playerRepository: PlayerRepository = null
  var game: GameThread = null
  var scoreThread: ScoreThread = null
  final val adminPassword = (new scala.util.Random(new java.security.SecureRandom())).alphanumeric.take(ScalatraBootstrap.PasswordLength).mkString
  final val path = "/api/1"

  override def init(context: ServletContext): Unit = {
    appInit()

    logger.info("****************************")
    logger.info("***Administrator password***")
    logger.info(adminPassword)
    logger.info("****************************")

    context.mount(new AdminController(adminPassword, game, playerRepository), s"$path/admin
  def appInit(players: Option[PlayerRepository] = None): Unit = {
    playerRepository = players.getOrElse(new PlayerRepository(None))
    scoreThread = new ScoreThread(playerRepository)
    game = new GameThread(scoreThread)

    launchThreads
  }

  private def closeDbConnection: Unit = {
    playerRepository.closeConnection
  }

  override def destroy(context: ServletContext): Unit = {
    super.destroy(context)
    closeDbConnection

    scoreThread.running = false
    game.running = false
  }

  def launchThreads: Unit = {
    new Thread(scoreThread).start
    new Thread(game).start
  }
} 
开发者ID:DrPandemic,项目名称:aigar.io,代码行数:58,代码来源:ScalatraBootstrap.scala


注:本文中的javax.servlet.ServletContext类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。