これら 2 つの JavaScript 関数を作成しました。
function addIpSubmit()
{
var theForm = document.getElementById("login_form");
var userName = theForm.username.value;
userName = theForm.clientip.value + "#" + userName;
theForm.j_username.value = userName;
if( validate_required( theForm.username, "User ID is required" ) )
{
if( validate_required( theForm.j_password, "Password is required" ) )
{
theForm.submit();
}
}
}
function validate_required( field, alerttxt )
{
with (field)
{
if (value==null||value=="")
{
alert(alerttxt);
return false;
}
else
{
return true;
}
}
}
addIpSubmit は、ログイン ボタンから呼び出されます。IP アドレスを非表示フィールドに入れる Bean があることがわかります。j_username JAAS フィールドも隠され、addIpSubmit() 関数によって入力されます。
<input id="clientip" type="hidden" name="clientip" value="#{loginMBean.ip}"/>
<input id="j_username" type="hidden" name="j_username" />
<input type="button" name="OtherLogin" value="Login" onclick="addIpSubmit()" />
IP をユーザー名に変更し、JAAS 送信関数を呼び出します。次に、ログイン モジュールで、IP アドレスとユーザー名を取得します。
String userid = username;
if( username.contains( "#" ) )
{
ip = username.split( "#" )[0];
userid = username.split( "#" )[1];
}
FacesContext.getCurrentInstance().getExternalContext().getRemoteUser() に ip#userid が含まれるようになったことを覚えておいてください。