Ошибка создания бина с именем 'userController': неудовлетворенная зависимость выражена через поле 'userService - PullRequest
0 голосов
/ 16 марта 2019

ПРЕДУПРЕЖДЕНИЕ: Возникла исключительная ситуация во время инициализации контекста - отмена попытки обновления: org.springframework.beans.factory.UnsatisfiedDependencyException: Ошибка при создании компонента с именем 'userController': неудовлетворенная зависимость, выраженная через поле 'userService';вложенное исключение: org.springframework.beans.factory.UnsatisfiedDependencyException: ошибка при создании bean-компонента с именем 'userService': неудовлетворенная зависимость, выраженная через поле 'userDao';вложенное исключение - org.springframework.beans.factory.UnsatisfiedDependencyException: ошибка при создании bean-компонента с именем 'userDao': неудовлетворенная зависимость, выраженная через метод 'setJdbcTemplate', параметр 0;вложенное исключение: org.springframework.beans.factory.NoSuchBeanDefinitionException: отсутствует квалифицируемый компонент типа 'org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate': ожидается, что по крайней мере 1 компонент будет квалифицирован как кандидат для автоматической передачи.Аннотации зависимостей: {}

   **userController code**

        @Controller
        @RequestMapping("user")
        public class UserController {

        private UserService userService;

        @Autowired
        public void setUserService(UserService userService) {
            this.userService = userService;
        }



        //======== code for user data insert =============
        @GetMapping("/createuser")
        public String showUserform(Model theModel) {
            theModel.addAttribute("user", new User());
            return "userform";
        }

        //@RequestMapping(value = "/saveUser", method = RequestMethod.POST)
        @PostMapping("/saveuser")
        public String saveUser(@ModelAttribute("user") @Valid User user,BindingResult result) {

            if (result.hasErrors()) {
                return "userform";
            }

            user.setAuthority("ROLE_USER");
            user.setEnabled(true);

        return "usercreatesuccess";

        }
   **userservice code**

        @Service("userService")
        public class UserService {

        private UserDao userDao;

        @Autowired
        public void setUserDao(UserDao userDao) {
            this.userDao = userDao;`enter code here`
        }



        //======== code for user data insert =============
        public void saveUser(User user) {
            userDao.saveUser(user);
        }



        public boolean exists(String username) {
            return userDao.exists(username);
        }

   **userDao code**


         @Component("userDao")
         public class UserDao {

        private NamedParameterJdbcTemplate jdbcTemplate;

        /*
         * @Autowired private PasswordEncoder passwordEncoder;
         */

        @Autowired
        public void setJdbcTemplate(NamedParameterJdbcTemplate jdbcTemplate) {
            this.jdbcTemplate = jdbcTemplate;
        }





         //======== query for user data insert =============
         public boolean saveUser(User user) {

         MapSqlParameterSource params = new MapSqlParameterSource();

            params.addValue("username", user.getUsername());
            params.addValue("password", user.getPassword());
            params.addValue("firstname", user.getFirstname());
            params.addValue("lastname", user.getLastname());
            params.addValue("email", user.getEmail());
            params.addValue("enabled", user.isEnabled());
            params.addValue("authority", user.getAuthority());

            jdbcTemplate.update("insert into users ( username, firstname, lastname, password, email, enabled) values ( :username, :firstname, :lastname, :password, :email, :enabled)", params);
            return jdbcTemplate.update("insert into authorities (username, authority) values (:username, :authority)", params) == 1;

        }

        // query for Duplicate username
        public boolean exists(String username) {
            return jdbcTemplate.queryForObject("select count(*) from users where username=:username", new MapSqlParameterSource("username", username), Integer.class) > 0;
        }
   **[blog-servlet.xml][1]**
        <!-- Add support for component scanning -->
        <context:component-scan base-package="com.spring.mvc.blog.xml" />


        <!-- Add support for conversion, formatting and validation support -->
        <mvc:annotation-driven/>

        <!-- Define Spring MVC view resolver -->
        <bean
            class="org.springframework.web.servlet.view.InternalResourceViewResolver"
            id="jspViewResolver">
            <property name="prefix" value="/WEB-INF/view/" />
            <property name="suffix" value=".jsp" />
        </bean>

        <!-- Add support for reading web resources: css, images, js, etc ... -->
        <mvc:resources location="/resources/" mapping="/resources/**"></mvc:resources>

        <!-- connection for datasource -->
        <jee:jndi-lookup jndi-name="jdbc/spring" id="dataSource"
            expected-type="javax.sql.DataSource">
        </jee:jndi-lookup>

   **error** 

      [1]: https://i.stack.imgur.com/WZWVj.png

Ответы [ 2 ]

2 голосов
/ 16 марта 2019

Вам потребуется определить bean-компонент JdbcTemplate

@Bean
public JdbcTemplate jdbcTemplate(DataSource dataSource) {
   return new JdbcTemplate(dataSource);
}

Вам также потребуется компонент DataSource, который будет внедрен в bean-компонент jdbcTemplate:

@Bean
public DataSource datasource() {
    DataSource ds = new DataSource();
    ds.setDriverClassName(hostdb_driver);
    ds.setUrl(hostdb_url);
    ds.setUsername(hostdb_user);
    ds.setPassword(hostdb_pass);
    return ds;
}

Если вы не используете конфигурацию JavaВот XML-конфигурация:

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>

Чтобы зарегистрировать источник данных, который должен быть внедрен в bean-компонент jdbctemplate, вам потребуется поискать детали для конкретной базы данных, которую вы используете.Например, MYSQL и Oracle SQL будут иметь небольшие изменения.

<bean id="dataSource"
    class="org.springframework.jdbc.datasource.DriverManagerDataSource">

    <property name="driverClassName" value="com.mysql.jdbc.Driver" />
    <property name="url" value="jdbc:mysql://localhost:3306/databasename" />
    <property name="username" value="root" />
    <property name="password" value="password" />
</bean>

driverClassName и значение url будут отличаться для разных типов базы данных.

1 голос
/ 17 марта 2019

ApplicationContext не может инициализировать bean-компонент userDao.

UserDao зависит от NamedParameterJdbcTemplate

(Неудовлетворенная зависимость, выраженная с помощью параметра 0 метода setJdbcTemplate; вложенное исключение - org.springframework.beans.factory.NoSuchBeanDefinitionException: нет квалифицирующего компонента типа 'org.springframework.jdbc.core. namedparamj )0P0.

Вы должны создать bean-компонент типа NamedParameterJdbcTemplate в конфигурации Xml или Java.

@Bean 
public NamedParameterJdbcTemplate namedParameterJdbcTemplate (DataSource datasource){
     return new NamedParameterJdbcTemplate(dataSource);
}

Xml:

<bean id="namedParameterJdbcTemplate"  class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate">
        <constructor-arg ref="dataSource"/>
</bean>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...