Java活用生活

ログイン

オンライン状況

オンラインユーザー5人
ログインユーザー0人
登録ユーザー2人

カウンタ

COUNTER358001

日誌

Web Master
123456
2025/01/12

CSVダウンロードサンプル

固定リンク | by:aramaki
CSVダウンロードサンプル
---------------------------------------------
// メソッドの戻り値をResponseEntity型にすると、Thymeleafのテンプレート(html)ではなく、
// ファイル(byte型の配列)を呼び出し元に返却できる
@GetMapping("/accountList/csv")
public ResponseEntity<byte[]> getAccountListCsv(Model model) {

// ユーザーを全件取得して、CSVに保存する

byte[] bytes = null;

try {
service.accountCsvOut();
bytes = service.getFile(AccountRowCallBackHandler.PATH);
} catch (IOException e) {

e.printStackTrace();
}
// ダウンロードHTTPヘッダーの設定
HttpHeaders headers = new HttpHeaders();
headers.add("Content-Type", "text/csv; charset=UTF-8");
headers.setContentDispositionFormData("filename", "sample.csv");

// CSVダウンロード
return new ResponseEntity<>(bytes, headers, HttpStatus.OK);

}

15:12 | 投票する | 投票数(0) | コメント(0)
2025/01/10

Spring DataをJavaScriptで受け取る

固定リンク | by:aramaki

<scriptth:inline="javascript">

// Spring DataをJavaScriptで受け取る

constdatalist=/*[[${dataList}]]*/+'';

//const dat=document.getElementById("data");

letary=[];

datalist.forEach(function(dept){

//const dat=document.getElementById("data");

// Object をJSONデータへ

letdeptData=JSON.stringify(dept);

if(dept.deptno===10){

//dat.append(dept);

//console.log(dept.loc);

ary.push("'"+dept.dname+"'");

ary.push(":");

ary.push(dept);

}

conststr=ary.join("");

console.log(str);

});

01:06 | 投票する | 投票数(0) | コメント(0)
2024/11/29

MultiValueMapのサンプル

固定リンク | by:aramaki
Spring MultiValueMap
--------------------------------------------------------------------------------

抜粋)

MultiValueMap<String, String> params1 = new LinkedMultiValueMap<String, String>();
//同じキーに2つ追加する。
params1.add("a", "あ");
params1.add("a", "い");
//1つ目の値だけ取得する
String val = params1.getFirst("a"); //⇒"あ"
//あるキーの値をすべて取得する
List<String> list = params1.get("a"); //⇒"あ", "い"
//複数の値を一気に設定する
params1.put("b", Arrays.asList(new String[]{"う", "え"}));
//1つ目の値だけのMapを取得する
Map m = params1.toSingleValueMap();
//値を1つだけ設定する
params1.set("a", "お"); //⇒キー"a" の値が"お"だけになる
まず、MultiValueMapはインターフェースになっていて、以下のMapの派生インターフェースになっています。
Map<K, List<V>>
ですので、put()や、get()での値は、Listになります。
そして実体のクラスは、LinkedMultiValueMapになります。
10:08 | 投票する | 投票数(0) | コメント(0)
2024/11/05

Spring 失敗したJobを取得するSQL

固定リンク | by:aramaki
Spring 失敗したJobを取得するSQL
-------------------------------------------------------------------------------------------------------------------------------------
with v_failjob as (
select
    e.JOB_EXECUTION_ID JOB_EXECUTION_ID,
    e.VERSION VERSION,
    e.JOB_INSTANCE_ID JOB_INSTANCE_ID,
    e.CREATE_TIME CREATE_TIME,
    e.START_TIME START_TIME,
    e.END_TIME END_TIME,
    e.STATUS STATUS,
    e.EXIT_CODE EXIT_CODE,
    e.EXIT_MESSAGE EXIT_MESSAGE,
    e.LAST_UPDATED LAST_UPDATED
  from
    BATCH_JOB_EXECUTION e
      inner join
        BATCH_JOB_INSTANCE i
      on
        e.JOB_INSTANCE_ID=i.JOB_INSTANCE_ID
  where
    i.JOB_NAME='importUserJob' and
    e.EXIT_CODE != 'COMPLETED'
  order by e.LAST_UPDATED)
-- 失敗したjobのJOB_EXECUTION_IDを取得する
select * from v_failjob where JOB_EXECUTION_ID=(select Max(JOB_EXECUTION_ID) from v_failjob)

    --and e.LAST_UPDATED=(select Max(e.LAST_UPDATED) from BATCH_JOB_EXECUTION)
    --------------------------------------------------------------------------------------------------------------------------------------
11:03 | 投票する | 投票数(0) | コメント(0)
2024/07/10

MyBatis SQLを呼び出すサンプル

固定リンク | by:aramaki
MyBatis SQLを呼び出すサンプル
---------------------------------------------------------------
public void callSql() throws IOException {
String resource="demo/mybatis.xml";
Reader reader=Resources.getResourceAsReader(resource);
SqlSessionFactory factory=new SqlSessionFactoryBuilder().build(reader);

// sessionを取得する
SqlSession session=factory.openSession();// トランザクションを開始
Animal animal=session.selectOne("sample.dao.AnimalMapper.selectAnimal",1);
session.close();
}
14:04 | 投票する | 投票数(0) | コメント(0)
2024/05/09

application.propertiesサンプル

固定リンク | by:aramaki
#spring.jpa.hibernate.ddl-auto=create
spring.datasource.driver-class-name=oracle.jdbc.driver.OracleDriver
spring.datasource.url=jdbc:oracle:thin:@192.168.11.123:1521/pdborcl2
spring.datasource.username=pdbadmin
spring.datasource.password=aramaki3$$
spring.jpa.database-platform=org.hibernate.dialect.OracleDialect
spring.jpa.show-sql=true
09:34 | 投票する | 投票数(0) | コメント(0)
2024/04/20

Spring Security Version6以降の対応について

固定リンク | by:aramaki
Spring Securityを利用して、ログイン処理を実装しようと、以下のサイトを
参考に、実装したが、すでにバージョンが、6以降になっていて、削除されたクラスも
あり、作成できないため、改めて作成しました。
尚、ログインページは、Springの自動作成ページではなく、自作の「login2.html」
、またDBはORCL19Cです。

【Java・SpringBoot】Springセキュリティ④ - ログイン処理の実装
https://qiita.com/suema0331/items/886c0345c9a6172c64ac


【実装コード】SecurityConfig.java
--------------------------------------------------------------------------------------------------------
import javax.sql.DataSource;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
import org.springframework.security.config.annotation.method.configuration.EnableMethodSecurity;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.core.SpringSecurityCoreVersion;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.security.web.SecurityFilterChain;
import org.springframework.security.web.util.matcher.AntPathRequestMatcher;


@EnableWebSecurity 
@EnableMethodSecurity
@Configuration
public class SecurityConfig {
@Autowired
private DataSource dataSource;
// パスワードエンコーダーBean
@Bean
PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}

    @Bean
    SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {
   
    // 認証するユーザーの情報をデータベースからロードする
String userSql="select user_Id,password, 1 as ENABLED from Account where user_Id=?";// Oracleにboolean型がない
String roleSql="select user_Id,ACCOUNT_GROUP as ROLE from Account  where user_Id=?";

    AuthenticationManagerBuilder authBuilder=http.getSharedObject(AuthenticationManagerBuilder.class);
    authBuilder.jdbcAuthentication()
.dataSource(dataSource)
.usersByUsernameQuery(userSql)
.authoritiesByUsernameQuery(roleSql)
    .passwordEncoder(passwordEncoder());
   
    // バージョンログ
    String springSecurityVersion = SpringSecurityCoreVersion.getVersion();
    System.out.println("Spring Security Version: " + springSecurityVersion);
      
// ログインページ設定
http.authorizeHttpRequests(
authz -> authz.requestMatchers("/css/**").permitAll()
.requestMatchers("/js/**").permitAll()
.requestMatchers("/login2").permitAll()
.requestMatchers("/admin/").permitAll()
.requestMatchers("/signup").permitAll()
.requestMatchers("/admin/**").hasRole("ADMIN") // admin権限しかアクセスできない。
.anyRequest().authenticated() // 上記URL以外は認証が必要
);
// ログイン処理
http.formLogin(login -> login  //HttpSecurity
.loginProcessingUrl("/login2") // ログイン処理Path
.loginPage("/login2")
.failureUrl("/login2") // ログイン認証失敗時の遷移先
.usernameParameter("userId")
.passwordParameter("password")
.defaultSuccessUrl("/home",true) 
.permitAll());

        // ログアウト処理
        http.logout(logout -> logout
                .logoutRequestMatcher(new AntPathRequestMatcher("/logout"))
                .logoutSuccessUrl("/login2")
                // セッション無効化
                .deleteCookies("JSESSIONID").invalidateHttpSession(true).permitAll());
        // CRFS対策を無効
        http.csrf(csrf -> csrf.disable());

return http.build();
}
    
}

11:33 | 投票する | 投票数(0) | コメント(0)
2024/02/11

Spring pom.xmlにJAXBなど使用できるようにする

固定リンク | by:aramaki
Spring pom.xmlにJAXBなど使用できるようにする。
----------------------------------------------------------------------
<!-- JAXB -->
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-core</artifactId>
</dependency>
<dependency>
<groupId>javax.xml.bind</groupId>
<artifactId>jaxb-api</artifactId>
<version>2.3.1</version>
</dependency>
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-impl</artifactId>
</dependency>
<dependency>
<groupId>org.javassist</groupId>
<artifactId>javassist</artifactId>
<version>3.25.0-GA</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

<!-- JPAによるデータベースの利用 Spring Boot Starter Data JPA -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

22:01 | 投票する | 投票数(0) | コメント(0)
2023/03/08

簡易ログ表示関数

固定リンク | by:aramaki
簡易ログ表示関数
-------------------------------------
 void log(String message) {
System.out.printf("[%s] %s%n", LocalDateTime.now(), message);
 }
12:01 | 投票する | 投票数(0) | コメント(0)
2023/02/26

Jquery select 選択値で、別のselectのoptionを変更

固定リンク | by:aramaki
jQuery select 選択値で、別のselectのoptionを変更
----------------------------------------------------------------------------

実行結果
ここをクリック

----------------------------
     ソースコード
----------------------------

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.4.0/jquery.mobile-1.4.0.min.css" />
    <script src="http://code.jquery.com/jquery-1.10.2.min.js"></script>
    <script src="http://code.jquery.com/mobile/1.4.0/jquery.mobile-1.4.0.min.js"></script>
    <script type="text/javascript">
      $(function(){
        let data0 =[{name:"",id:"0"}];

        let data1=[{name:"",id:"0"},{name:"東京",id:"1"},{name:"大阪",id:"2"},{name:"京都",id:"3"}];

        let data2=[{name:"",id:"0"},{name:"ワシントン",id:"1"},{name:"シアトル",id:"2"},{name:"コロラド",id:"3"}];

        let data3=[{name:"",id:"0"},{name:"北京",id:"1"},{name:"上海",id:"2"},{name:"香港",id:"3"}];

        let city_data = undefined;

        // 地域エリアを選択した場合、対応するオプションがselect要素に設定する。
        $('[name = area]').on('change',function(){
          let area_val = $(this).val();
          
          switch(area_val){
            case "0" :
            city_data = data0;
            break;
            case "1":
            city_data = data1;
            break;
            case "2" :
            city_data = data2;
            break;
            case "3" :
            city_data = data3;
            break;
            default:
              break;

          }
            // selectタグのoption値を一旦削除
            $('[name = city] option').remove();
            // 新たにoptionを設定する。
            let selectItem = "";
            $.each(city_data,function(index,data){
              
              $('[name = city]').append($('<option>').text(data.name).val(data.id));
              if(index == 1){
                // data1 data2 data3の2番目の値を選択状態にする。
                selectItem = data.id;
              }             

            });

            $('[name = city] option').attr("selected", false);

            $('[name = city]').val(selectItem);

            $('[name = city]').selectmenu('refresh');             
 
        })
        
      });


    </script>
  </head>

  <body>
    <div>
      <div class="form">
       <form name="country" >
        <label for="area_name">国名</label>
        
        <select id="area_name" name="area" size="1">
            <option value="0"></option>
            <option value="1">日本</option>
            <option value="2">アメリカ</option>
            <option value="3">中国</option>
        </select>
        <label for="city _name">都市名</label>
        <select id="city _name" name="city" size="1">
            <option value="0"></option>
            <option value="1">ワシントン</option>
            <option value="2">シアトル</option>
            <option value="3">コロラド</option>
        </select>

       </form>
    </div>
  </body>
</html>






21:16 | 投票する | 投票数(0) | コメント(0)
123456
Copyright © Java活用生活 All Rights Reserved .