Sunday, 6 November 2016

import a file/dependencies from repositories - maven (pom.xml)

<properties>
   <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
   <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
   <sqljdbc.version>4.0</sqljdbc.version>
</properties>

<repositories>
   <repository>
      <id>API_Repository</id>
      <name>API Repository</name>
      <url>file:\\sharedDrive\location\sample\jarsfolder</url>
   </repository>
</repositories>

<dependencies>
   <dependency>
      <groupId>com.microsoft.sqlserver</groupId>
      <artifactId>sqljdbc</artifactId>
      <version>${sqljdbc.version}</version>
   </dependency>
</dependencies>



difference between maven compile vs provided

compile
This is the default scope, used if none is specified. Compile dependencies are available in all classpaths of a project. Furthermore, those dependencies are propagated to dependent projects.

provided
This is much like compile, but indicates you expect the JDK or a container to provide the dependency at runtime. For example, when building a web application for the Java Enterprise Edition, you would set the dependency on the Servlet API and related Java EE APIs to scope provided because the web container provides those classes. This scope is only available on the compilation and test classpath, and is not transitive.

=============================================================

compile
Make available into class path, don't add this dependency into final jar if it is normal jar; but add this jar into jar if final jar is a single jar (for example, executable jar)

provided
Dependency will be available at run time environment so don't add this dependency in any case; even not in single jar (i.e. executable jar etc)

==============================================================

Compile means that you need the JAR for compiling and running the app. For a web application, as an example, the JAR will be placed in the WEB-INF/lib directory.

Provided means that you need the JAR for compiling, but at run time there is already a JAR provided by the environment so you don't need it packaged with your app. For a web app, this means that the JAR file will not be placed into the WEB-INF/lib directory.

For a web app, if the app server already provides the JAR (or its functionality), then use "provided" otherwise use "compile".

Different types of scope in maven pom.xml

The <scope> element can take 6 value: compile, provided, runtime, test, system and import.

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-test</artifactId>
   <scope>test</scope>
</dependency>


compile
This is the default scope, used if none is specified. Compile dependencies are available in all classpaths of a project. Furthermore, those dependencies are propagated to dependent projects.
provided
This is much like compile, but indicates you expect the JDK or a container to provide the dependency at runtime. For example, when building a web application for the Java Enterprise Edition, you would set the dependency on the Servlet API and related Java EE APIs to scope provided because the web container provides those classes. This scope is only available on the compilation and test classpath, and is not transitive.
runtime
This scope indicates that the dependency is not required for compilation, but is for execution. It is in the runtime and test classpaths, but not the compile classpath.
test
This scope indicates that the dependency is not required for normal use of the application, and is only available for the test compilation and execution phases.
system
This scope is similar to provided except that you have to provide the JAR which contains it explicitly. The artifact is always available and is not looked up in a repository.
import (only available in Maven 2.0.9 or later)
This scope is only used on a dependency of type pom in the section. It indicates that the specified POM should be replaced with the dependencies in that POM's section. Since they are replaced, dependencies with a scope of import do not actually participate in limiting the transitivity of a dependency.

Friday, 4 November 2016

Missing URI template variable - Spring MVC issue - Troubleshoot

{
  "timestamp": 1478261692885,
  "status": 500,
  "error": "Internal Server Error",
  "exception": "org.springframework.web.bind.MissingPathVariableException",
  "message": "Missing URI template variable 'id' for method parameter of type String",
  "path": "/admin/3"
}


@RestController
public class ApiAdminController {

    @RequestMapping(name = "/admin/{id}", method = RequestMethod.GET)
    public ResponseEntity<Set<Object[]>> getPermissions(@PathVariable String id){
                .......
                .......
                }
}

Solution : Change name to value in @RequestMapping

@RestController
public class ApiAdminController {

    @RequestMapping(value = "/admin/{id}", method = RequestMethod.GET)
    public ResponseEntity<Set<Object[]>> getPermissions(@PathVariable String id){
                .......
                .......
                }
}